.advanced-cropper-line-wrapper--north,.advanced-cropper-line-wrapper--south{width:100%;height:12px}.advanced-cropper-line-wrapper--north{cursor:n-resize}.advanced-cropper-line-wrapper--south{cursor:s-resize}.advanced-cropper-line-wrapper--east,.advanced-cropper-line-wrapper--west{width:12px;height:100%}.advanced-cropper-line-wrapper--east{cursor:e-resize}.advanced-cropper-line-wrapper--west{cursor:w-resize}.advanced-cropper-line-wrapper--disabled{cursor:auto}.advanced-cropper-line-wrapper__content{position:absolute}.advanced-cropper-line-wrapper__content--east,.advanced-cropper-line-wrapper__content--west{height:100%}.advanced-cropper-line-wrapper__content--north,.advanced-cropper-line-wrapper__content--south{width:100%}.advanced-cropper-line-wrapper__content--east{left:50%;transform:translate(-100%)}.advanced-cropper-line-wrapper__content--west{right:50%;transform:translate(100%)}.advanced-cropper-line-wrapper__content--north{top:50%}.advanced-cropper-line-wrapper__content--south{bottom:50%}.advanced-cropper-handler-wrapper{width:30px;height:30px;position:absolute;transform:translate(-50%,-50%)}.advanced-cropper-handler-wrapper__draggable{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.advanced-cropper-handler-wrapper--west-north{cursor:nw-resize}.advanced-cropper-handler-wrapper--north{cursor:n-resize}.advanced-cropper-handler-wrapper--east-north{cursor:ne-resize}.advanced-cropper-handler-wrapper--east{cursor:e-resize}.advanced-cropper-handler-wrapper--east-south{cursor:se-resize}.advanced-cropper-handler-wrapper--south{cursor:s-resize}.advanced-cropper-handler-wrapper--west-south{cursor:sw-resize}.advanced-cropper-handler-wrapper--west{cursor:w-resize}.advanced-cropper-handler-wrapper--disabled{cursor:auto}.advanced-cropper-bounding-box{width:100%;height:100%;position:relative}.advanced-cropper-bounding-box__handler-wrapper{position:absolute}.advanced-cropper-bounding-box__handler-wrapper--east,.advanced-cropper-bounding-box__handler-wrapper--west{height:100%;top:50%;transform:translateY(-50%)}.advanced-cropper-bounding-box__handler-wrapper--south,.advanced-cropper-bounding-box__handler-wrapper--north{width:100%;left:50%;transform:translate(-50%)}.advanced-cropper-bounding-box__handler-wrapper--west,.advanced-cropper-bounding-box__handler-wrapper--west-north,.advanced-cropper-bounding-box__handler-wrapper--west-south{left:0}.advanced-cropper-bounding-box__handler-wrapper--east,.advanced-cropper-bounding-box__handler-wrapper--east-north,.advanced-cropper-bounding-box__handler-wrapper--east-south{left:100%}.advanced-cropper-bounding-box__handler-wrapper--north,.advanced-cropper-bounding-box__handler-wrapper--west-north,.advanced-cropper-bounding-box__handler-wrapper--east-north{top:0}.advanced-cropper-bounding-box__handler-wrapper--south,.advanced-cropper-bounding-box__handler-wrapper--west-south,.advanced-cropper-bounding-box__handler-wrapper--east-south{top:100%}.advanced-cropper-bounding-box__handler{position:absolute}.advanced-cropper-bounding-box__handler--west-north{top:0;left:0}.advanced-cropper-bounding-box__handler--north{top:0;left:50%}.advanced-cropper-bounding-box__handler--east-north{top:0;left:100%}.advanced-cropper-bounding-box__handler--east{top:50%;left:100%}.advanced-cropper-bounding-box__handler--east-south{top:100%;left:100%}.advanced-cropper-bounding-box__handler--south{top:100%;left:50%}.advanced-cropper-bounding-box__handler--west-south{top:100%;left:0}.advanced-cropper-bounding-box__handler--west{top:50%;left:0}.advanced-cropper-bounding-box__line{position:absolute}.advanced-cropper-bounding-box__line--north,.advanced-cropper-bounding-box__line--south{left:0;transform:translateY(-50%)}.advanced-cropper-bounding-box__line--north{top:0}.advanced-cropper-bounding-box__line--south{top:100%}.advanced-cropper-bounding-box__line--west,.advanced-cropper-bounding-box__line--east{top:0;transform:translate(-50%)}.advanced-cropper-bounding-box__line--west{left:0}.advanced-cropper-bounding-box__line--east{left:100%}.advanced-cropper-artificial-transition{will-change:transform}.advanced-cropper-background-image{-webkit-user-select:none;user-select:none;transform-origin:50%;pointer-events:none;position:absolute;max-width:none!important}.advanced-cropper-canvas{display:none}.advanced-cropper-source{visibility:hidden;opacity:0;width:1px;height:1px;position:absolute}.advanced-cropper-fade{visibility:hidden;opacity:0;flex-direction:column;transition:all .5s;display:flex}.advanced-cropper-fade--visible{opacity:1;visibility:visible}.advanced-cropper-wrapper__fade{flex-grow:1;min-height:0}.advanced-cropper-stencil-grid{border-collapse:collapse;table-layout:fixed;opacity:0;transition:opacity .3s;display:table}.advanced-cropper-stencil-grid--visible{opacity:1}.advanced-cropper-stencil-grid__row{display:table-row}.advanced-cropper-stencil-grid__cell{border:1px solid;width:1%;height:1%;display:table-cell}.advanced-cropper-stencil-grid__cell--top{border-top-color:#0000}.advanced-cropper-stencil-grid__cell--left{border-left-color:#0000}.advanced-cropper-stencil-grid__cell--right{border-right-color:#0000}.advanced-cropper-stencil-grid__cell--bottom{border-bottom-color:#0000}.advanced-cropper-stencil-overlay{box-sizing:content-box;pointer-events:none;-webkit-backface-visibility:hidden;width:100%;height:100%;position:absolute;box-shadow:0 0 0 1000px}.advanced-cropper-stencil-wrapper{will-change:transform}.advanced-cropper-boundary{-webkit-user-select:none;user-select:none;direction:ltr;position:relative}.advanced-cropper-boundary__content{width:100%;height:100%;position:absolute;top:0;left:0}.advanced-cropper-boundary__stretcher{pointer-events:none;max-width:100%;max-height:100%;position:relative}.advanced-cropper-circle-stencil{box-sizing:content-box;-webkit-backface-visibility:hidden;width:100%;height:100%;-webkit-transform-style:preserve-3d;position:absolute}.advanced-cropper-circle-stencil__overlay{border-radius:50%;overflow:hidden}.advanced-cropper-circle-stencil__preview{border-radius:50%}.advanced-cropper-circle-stencil__draggable-area,.advanced-cropper-circle-stencil__overlay,.advanced-cropper-circle-stencil__preview,.advanced-cropper-circle-stencil__grid{width:100%;height:100%;position:absolute}.advanced-cropper-circle-stencil--movable{cursor:move}.advanced-cropper-rectangle-stencil{box-sizing:border-box;-webkit-backface-visibility:hidden;width:100%;height:100%;-webkit-transform-style:preserve-3d;position:absolute}.advanced-cropper-rectangle-stencil__draggable-area,.advanced-cropper-rectangle-stencil__overlay,.advanced-cropper-rectangle-stencil__preview,.advanced-cropper-rectangle-stencil__grid{width:100%;height:100%;position:absolute}.advanced-cropper-rectangle-stencil--movable{cursor:move}.advanced-cropper-simple-line{background:0 0;border-width:0}.advanced-cropper-simple-line--south,.advanced-cropper-simple-line--north{width:100%;height:0}.advanced-cropper-simple-line--east,.advanced-cropper-simple-line--west{width:0;height:100%}.advanced-cropper-simple-line--east{border-right-width:1px}.advanced-cropper-simple-line--west{border-left-width:1px}.advanced-cropper-simple-line--south{border-bottom-width:1px}.advanced-cropper-simple-line--north{border-top-width:1px}.advanced-cropper-simple-handler{display:block}.advanced-cropper-preview{box-sizing:border-box;flex-direction:column;display:flex;position:relative;overflow:hidden}.advanced-cropper-preview__content{position:absolute;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.advanced-cropper-preview__image{pointer-events:none;-webkit-user-select:none;user-select:none;transform-origin:50%;display:none;position:absolute;max-width:none!important}.advanced-cropper-preview__image--visible{display:block}.advanced-cropper-preview__boundary{flex-grow:1;min-width:0;min-height:0}.cropper-preview-wrapper__fade{flex-grow:1;width:100%;min-height:0}.advanced-cropper{color:#fff;background:#000;flex-direction:column;max-height:100%;display:flex;position:relative;overflow:hidden}.advanced-cropper__boundary{flex-grow:1;min-width:0;min-height:0}.advanced-cropper__wrapper,.advanced-cropper__background-wrapper{position:absolute;inset:0}.advanced-cropper__stencil-wrapper{position:absolute}.advanced-cropper *{box-sizing:border-box}.advanced-cropper-simple-handler{background:currentColor;width:10px;height:10px}.advanced-cropper-simple-line{border-style:solid;border-color:#ffffff4d;transition:border .5s}.advanced-cropper-simple-line--hover{border-color:#fff}.advanced-cropper-circle-stencil__preview{border:2px solid #fff3}.advanced-cropper-stencil-overlay{color:#00000080}.advanced-cropper-stencil-grid{color:#fff6}:root,[data-theme=light]{--teal:#25878c;--teal-dark:#1c6a6e;--teal-light:#e8f4f4;--gold:#d1b26b;--gold-light:#f5ecd8;--navy:#132c3c;--cream:#f7f5f0;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-500:#6b7280;--gray-700:#374151;--red:#ef4444;--white:#fff;--bg:#f7f5f0;--bg-card:#fff;--bg-panel:#fff;--bg-input:#fff;--text:#132c3c;--text-muted:#6b7280;--text-faint:#aaa;--border:#00000014;--shadow:0 2px 8px #0000001a;--shadow-lg:0 4px 16px #0000001f;--radius:8px;--radius-lg:12px}[data-theme=dark]{--navy:#e4e6eb;--cream:#0f1118;--gray-100:#1a1d28;--gray-200:#252836;--gray-300:#353848;--gray-500:#8b90a0;--gray-700:#c8cad4;--white:#171924;--bg:#0c0e16;--bg-card:#151722;--bg-panel:#121420;--bg-input:#1e2030;--text:#e4e6eb;--text-muted:#8b90a0;--text-faint:#555868;--border:#ffffff0f;--shadow:0 2px 12px #00000080;--shadow-lg:0 8px 32px #0009;--red:#f87171;--teal-light:#25878c1f;--gold-light:#d1b26b14;--card-glow:0 0 0 1px #ffffff0a, 0 2px 12px #00000080}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--cream);color:var(--navy);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:hidden}.app{flex-direction:column;min-height:100vh;display:flex}.login-screen{background:linear-gradient(135deg,#0f2027 0%,#132c3c 40%,#1a4a4e 70%,#25878c 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--white);text-align:center;border-radius:20px;width:100%;max-width:400px;padding:48px 40px;box-shadow:0 20px 60px #0000004d}.login-logo{margin-bottom:24px}.login-logo-img{object-fit:contain;width:auto;height:48px}.login-title{color:var(--navy);letter-spacing:-.02em;margin-bottom:8px;font-size:24px;font-weight:700}.login-subtitle{color:var(--gray-500);margin-bottom:32px;font-size:14px;line-height:1.5}.login-form{flex-direction:column;gap:16px;display:flex}.login-field input{border:1.5px solid var(--gray-200);width:100%;color:var(--navy);background:var(--gray-100);border-radius:12px;outline:none;padding:14px 16px;font-size:15px;transition:all .2s}.login-field input:focus{border-color:var(--teal);background:var(--white);box-shadow:0 0 0 3px #25878c1a}.login-field input::placeholder{color:var(--gray-500)}.login-error{color:#dc2626;text-align:left;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:10px 14px;font-size:13px}.login-submit{background:linear-gradient(135deg, var(--teal) 0%, var(--teal-dark) 100%);color:var(--white);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:14px;font-size:15px;font-weight:700;transition:all .3s;display:flex;box-shadow:0 4px 14px #25878c4d}.login-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #25878c66}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-footer{color:var(--gray-500);letter-spacing:.05em;margin-top:32px;font-size:12px}@media (width<=480px){.login-card{border-radius:16px;padding:36px 24px}}.gallery-page{width:100%;max-width:1200px;margin:0 auto;padding:20px}.gallery-header{text-align:center;z-index:10;background:var(--cream);margin-bottom:24px;padding-bottom:12px;position:sticky;top:0}.gallery-title{letter-spacing:4px;text-transform:uppercase;color:var(--navy);margin-bottom:16px;font-size:28px;font-weight:300}.gallery-actions{margin-bottom:16px}.btn-upload-interior{background:var(--teal);color:var(--white);border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .2s;display:inline-flex}.btn-upload-interior:hover{background:var(--teal-dark)}.gallery-search{max-width:400px;margin:0 auto}.search-input{border:1px solid var(--gray-300);border-radius:var(--radius);background:var(--white);outline:none;width:100%;padding:10px 16px;font-size:14px;transition:border-color .2s}.search-input:focus{border-color:var(--teal)}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.gallery-empty{text-align:center;color:var(--gray-500);padding:60px 20px}.gallery-empty p{margin-bottom:8px}.gallery-card{background:var(--white);cursor:pointer;border-radius:12px;flex-direction:column;min-width:0;display:flex;position:relative;overflow:visible;box-shadow:0 1px 4px #00000014}.gallery-card-image{aspect-ratio:4/3;background:var(--gray-100);border-radius:12px 12px 0 0;position:relative;overflow:hidden}.gallery-card-image img{object-fit:cover;width:100%;height:100%;display:block}.gallery-card-placeholder{background:linear-gradient(135deg,#f5f1e8,#e9e1d3);width:100%;height:100%}.gallery-card-delete-btn{width:26px;height:26px;color:var(--white);cursor:pointer;z-index:2;opacity:0;background:#00000073;border:0;border-radius:50%;justify-content:center;align-items:center;transition:opacity .15s,background .15s;display:inline-flex;position:absolute;top:8px;right:8px}.gallery-card:hover .gallery-card-delete-btn{opacity:1}.gallery-card-delete-btn:hover{background:var(--red)}@media (hover:none),(width<=768px){.gallery-card-delete-btn{opacity:1}}.gallery-card-info{align-items:center;gap:0;min-width:0;padding:8px 4px 8px 10px;display:flex;position:relative;overflow:hidden}.gallery-card-meta{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.gallery-card-name{color:var(--navy);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:13px;font-weight:600;line-height:1.3;display:block;overflow:hidden}.card-time{color:#aaa;white-space:nowrap;font-size:10px;line-height:1.3}.gallery-card-menu-btn{cursor:pointer;color:#999;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:color .15s,background .15s;display:flex}.gallery-card-menu-btn:hover{color:var(--navy);background:#0000000d}.gallery-card-dropdown{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100;min-width:140px;position:absolute;top:32px;right:8px;overflow:hidden}.gallery-card-dropdown button{cursor:pointer;width:100%;color:var(--navy);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.gallery-card-dropdown button:hover{background:var(--gray-100)}.gallery-card-dropdown button.danger{color:var(--red)}.gallery-card-dropdown button.danger:hover{background:#fef2f2}.editor-page{flex-direction:column;height:100vh;display:flex;overflow:hidden}.editor-header{background:var(--white);border-bottom:1px solid var(--gray-200);z-index:60;align-items:center;gap:8px;min-height:48px;padding:8px 12px;display:flex;position:relative}.btn-icon{cursor:pointer;color:var(--navy);background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;display:flex}.btn-icon:hover{background:var(--gray-100)}.editor-title{flex:1;align-items:center;gap:4px;display:flex}.title-text{cursor:pointer;font-size:16px;font-weight:600}.title-text:hover{color:var(--teal)}.title-input{border:1px solid var(--teal);border-radius:4px;outline:none;width:200px;padding:2px 6px;font-size:16px;font-weight:600}.save-indicator{color:var(--gold);font-size:18px}.editor-header-actions{gap:8px;display:flex}.btn-export,.btn-save{border:1px solid var(--gray-300);border-radius:var(--radius);background:var(--white);cursor:pointer;letter-spacing:.5px;color:var(--navy);align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;display:flex}.btn-export:hover,.btn-save:hover{background:var(--gray-100)}.btn-save{background:linear-gradient(180deg, #fffdfa 0%, var(--gold-light) 100%);border-color:#d1b26b8c}.btn-save:disabled,.btn-export:disabled{opacity:.55;cursor:wait}.editor-canvas-area{background:#f7f5f0;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.canvas-container{width:100%;height:100%;transition:box-shadow .2s,background .2s}.canvas-container canvas{display:block}.canvas-error-state{color:var(--navy);text-align:center;box-shadow:var(--shadow-lg);background:#f7f5f0f5;border:1px solid #d1b26b66;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;display:flex;position:absolute;inset:16px}.canvas-error-state strong{letter-spacing:.6px;text-transform:uppercase;color:var(--gold);font-size:14px}.canvas-error-state span{color:var(--gray-700);font-size:13px}.canvas-container-drop-active{background:radial-gradient(circle,#25878c0f 0%,#25878c05 48%,#0000 72%);box-shadow:inset 0 0 0 2px #25878ca6}.editor-panel-area{background:var(--white);border-top:1px solid var(--gray-200);overflow:auto hidden}.tab-bar{background:var(--white);border-top:1px solid var(--gray-200);z-index:20;padding:4px 0;display:flex}.tab-item{cursor:pointer;color:var(--gray-500);letter-spacing:.5px;text-transform:uppercase;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;padding:6px 4px;font-size:10px;font-weight:600;transition:color .2s;display:flex;position:relative}.tab-item:hover{color:var(--navy)}.tab-active{color:var(--teal)}.tab-active:after{content:"";background:var(--teal);border-radius:0 0 2px 2px;height:2px;position:absolute;top:0;left:20%;right:20%}@media (width<=767px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:12px}.gallery-title{letter-spacing:3px;font-size:22px}.desktop-only{display:none}.editor-header-actions{gap:6px}.btn-icon{background:#132c3c0f;border:1px solid #132c3c14;justify-content:center;width:36px;height:36px}.btn-export,.btn-save{justify-content:center;min-width:36px;padding:6px 8px}}@media (width>=768px) and (width<=1023px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=1024px){.gallery-grid{grid-template-columns:repeat(4,1fr)}.gallery-page{padding:32px 40px}}.menu-wrapper{z-index:30;position:relative}.header-dropdown{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100;min-width:160px;position:absolute;top:36px;right:0;overflow:hidden}.header-dropdown button{cursor:pointer;width:100%;color:var(--navy);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.header-dropdown button:hover{background:var(--gray-100)}.header-dropdown button:disabled{opacity:.4;cursor:not-allowed}.setup-walls-bar{z-index:30;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.setup-walls-content{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-lg);color:var(--white);box-shadow:var(--shadow-lg);background:#132c3ce6;align-items:center;gap:8px;padding:8px 16px;display:flex}.setup-walls-label{letter-spacing:1px;text-transform:uppercase;white-space:nowrap;font-size:12px;font-weight:700}.setup-walls-actions{gap:6px;display:flex}.btn-setup{color:var(--white);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #ffffff4d;border-radius:6px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.btn-setup:hover{background:#ffffff1a}.btn-setup:disabled{opacity:.5;cursor:not-allowed}.btn-done{background:var(--teal);border-color:var(--teal);font-weight:700}.btn-done:hover{background:var(--teal-dark)}.btn-cancel{opacity:.7;border-color:#0000}.btn-cancel:hover{opacity:1}.setup-walls-error{color:#fca5a5;white-space:nowrap;font-size:11px}.spinner-small{border:2px solid #ffffff4d;border-top-color:var(--white);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin;display:inline-block}.panel{padding:12px 16px}.panel-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.panel-title{letter-spacing:1px;text-transform:uppercase;color:var(--teal);font-size:11px;font-weight:700}.panel-hint{color:var(--gray-500);font-size:11px}.panel-warn{color:var(--gold);font-size:11px;font-style:italic}.panel-empty{text-align:center;color:var(--gray-500);padding:16px;font-size:13px}.panel-placeholder{text-align:center;color:var(--gray-500);padding:20px}.panel-placeholder p{margin-top:8px;font-size:14px}.panel-placeholder-sub{opacity:.7;font-size:12px}.artworks-carousel{-webkit-overflow-scrolling:touch;gap:10px;padding-bottom:4px;display:flex;overflow-x:auto}.artwork-card{background:var(--white);cursor:pointer;text-align:center;border:1px solid #d6e3e3;border-radius:12px;flex:none;width:96px;padding:0;transition:border-color .2s,transform .2s,box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 10px 18px #132c3c0f}.artwork-card:hover{border-color:var(--gold);transform:translateY(-1px);box-shadow:0 14px 28px #132c3c1f}.artwork-card-active{border-color:var(--teal);box-shadow:0 0 0 2px #25878c2e}.artwork-card[draggable=true]{cursor:grab}.artwork-card[draggable=true]:active{cursor:grabbing}.artwork-card:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.artwork-card img{aspect-ratio:1;object-fit:cover;background:var(--cream);width:100%;display:block}.artwork-card-placeholder{aspect-ratio:1;background:var(--cream);width:100%;display:block}.artwork-card-name{color:var(--navy);white-space:nowrap;text-overflow:ellipsis;padding:6px 8px 0;font-size:10px;font-weight:700;display:block;overflow:hidden}.artwork-card-size{color:var(--gray-500);padding:2px 8px 8px;font-size:9px;display:block}.artwork-upload-btn{border:1px dashed var(--teal)!important;background:linear-gradient(#fff 0%,#eef7f6 100%)!important}.artwork-upload-btn:hover{border-color:var(--gold)!important}.upload-icon-wrapper{aspect-ratio:1;background:linear-gradient(#25878c14 0%,#f7f5f0 100%);justify-content:center;align-items:center;width:100%;display:flex}.artwork-card-delete{width:22px;height:22px;color:var(--white);cursor:pointer;background:#132c3ccc;border:0;border-radius:999px;justify-content:center;align-items:center;font-size:14px;line-height:1;display:inline-flex;position:absolute;top:6px;right:6px}.artwork-card-delete:hover{background:var(--gold);color:var(--navy)}.artwork-empty-state{background:#f7f5f0e6;border:1px dashed #25878c59;border-radius:12px;margin-top:10px}.mobile-artwork-drag-ghost{pointer-events:none;z-index:2000;background:var(--white);border:2px solid #25878cb3;border-radius:12px;width:88px;position:fixed;overflow:hidden;transform:translate(-50%,-50%)rotate(-4deg);box-shadow:0 18px 36px #132c3c42}.mobile-artwork-drag-ghost img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.size-controls{flex-direction:column;gap:8px;display:flex}.size-input-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.size-field{align-items:center;gap:4px;display:flex}.size-field label{color:var(--gray-500);min-width:14px;font-size:12px;font-weight:600}.size-field input{border:1px solid var(--gray-300);text-align:center;border-radius:4px;outline:none;width:60px;padding:4px 6px;font-size:13px}.size-field input:focus{border-color:var(--teal)}.size-unit{color:var(--gray-500);font-size:11px}.lock-btn{border:1px solid var(--gray-300);cursor:pointer;color:var(--gray-500);background:0 0;border-radius:4px;align-items:center;padding:4px;display:flex}.lock-btn:hover{color:var(--navy)}.lock-btn.locked{color:var(--teal);border-color:var(--teal)}.reset-btn{border:1px solid var(--gray-300);cursor:pointer;color:var(--gray-500);background:0 0;border-radius:4px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;display:flex}.reset-btn:hover{color:var(--navy)}.size-sliders,.position-controls{flex-direction:column;gap:6px;display:flex}.slider-row{align-items:center;gap:8px;display:flex}.slider-row label{color:var(--gray-500);min-width:14px;font-size:12px;font-weight:600}.slider-row input[type=range]{accent-color:var(--teal);flex:1;height:4px}.slider-value{color:var(--gray-500);text-align:right;min-width:35px;font-size:11px}.motif-controls{border-top:1px solid #d1b26b59;flex-direction:column;gap:8px;margin-top:8px;padding-top:10px;display:flex}.motif-header{justify-content:space-between;align-items:center;display:flex}.motif-title{letter-spacing:1px;text-transform:uppercase;color:var(--gold);font-size:11px;font-weight:700}.motif-value,.motif-axis-value{color:var(--navy);text-align:right;min-width:38px;font-size:11px;font-weight:600}.export-dropdown{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:200;min-width:160px;position:absolute;top:36px;right:0;overflow:hidden}.export-dropdown button{cursor:pointer;width:100%;color:var(--navy);background:0 0;border:none;align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.export-dropdown button:hover{background:var(--gray-100)}.export-dropdown button:disabled{opacity:.4}.export-loading{color:var(--gray-500);padding:6px 14px;font-size:11px;display:block}.calibration-bar{z-index:30;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.calibration-content{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-lg);color:var(--white);box-shadow:var(--shadow-lg);background:#132c3ce6;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 16px;display:flex}.calibration-label{letter-spacing:1px;text-transform:uppercase;white-space:nowrap;color:var(--gold);font-size:12px;font-weight:700}.calibration-hint{opacity:.8;white-space:nowrap;font-size:12px}.calibration-input-group{align-items:center;gap:4px;display:flex}.calibration-input{width:80px;color:var(--white);background:#ffffff1a;border:1px solid #ffffff4d;border-radius:4px;outline:none;padding:4px 8px;font-size:13px}.calibration-input:focus{border-color:var(--gold)}.calibration-input::placeholder{color:#fff6}.calibration-unit{opacity:.7;font-size:12px}.calibration-list{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.calibration-item{background:#ffffff26;border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;display:flex}.calibration-remove{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:12px}.calibration-remove:hover{color:var(--red)}.calibration-ratio{opacity:.6;font-size:11px}.zoom-indicator{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--white);z-index:25;background:#132c3ccc;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:flex;position:absolute;bottom:16px;right:16px}.zoom-reset-btn{cursor:pointer;color:#ffffffb3;background:0 0;border:none;align-items:center;padding:2px;display:flex}.zoom-reset-btn:hover{color:var(--white)}.gallery-header-top{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.gallery-tabs{gap:0;display:flex}.gallery-tab{color:var(--gray-500);letter-spacing:.05em;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:8px 24px;font-size:14px;font-weight:600;transition:all .2s}.gallery-tab:hover{color:var(--navy)}.gallery-tab-active{color:var(--teal);border-bottom-color:var(--teal)}.gallery-header-right{align-items:center;gap:8px;display:flex}.gallery-header-actions{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.auth-sync-btn{border:1px solid var(--gray-300);border-radius:var(--radius);background:var(--white);color:var(--gray-500);cursor:pointer;align-items:center;gap:6px;padding:6px 14px;font-size:13px;transition:all .2s;display:flex}.auth-sync-btn:hover{border-color:var(--teal);color:var(--teal)}.auth-user-btn{border:1px solid var(--teal-light);border-radius:var(--radius);background:var(--teal-light);color:var(--teal);cursor:pointer;align-items:center;gap:6px;padding:6px 14px;font-size:13px;display:flex}.auth-email{text-overflow:ellipsis;white-space:nowrap;max-width:150px;overflow:hidden}.auth-linked{position:relative}.auth-dropdown{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100;min-width:200px;margin-top:4px;padding:12px;position:absolute;top:100%;right:0}.auth-dropdown-email{color:var(--gray-500);margin-bottom:8px;font-size:12px}.auth-signout-btn{border:1px solid var(--gray-300);border-radius:var(--radius);background:var(--white);width:100%;color:var(--navy);cursor:pointer;padding:6px;font-size:13px}.auth-signout-btn:hover{background:var(--gray-100)}.auth-modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-modal{background:var(--white);border-radius:var(--radius-lg);width:90%;max-width:400px;box-shadow:var(--shadow-lg);padding:32px}.auth-modal h3{color:var(--navy);margin-bottom:8px}.auth-modal p{color:var(--gray-500);margin-bottom:16px;font-size:14px}.auth-modal form{flex-direction:column;gap:12px;display:flex}.auth-modal input[type=email]{border:1px solid var(--gray-300);border-radius:var(--radius);outline:none;padding:10px 14px;font-size:14px}.auth-modal input[type=email]:focus{border-color:var(--teal)}.auth-submit-btn{background:var(--teal);color:var(--white);border-radius:var(--radius);cursor:pointer;border:none;padding:10px;font-size:14px;font-weight:600}.auth-submit-btn:disabled{opacity:.6}.auth-modal input[type=password]{border:1px solid var(--gray-300);border-radius:var(--radius);outline:none;padding:10px 14px;font-size:14px}.auth-modal input[type=password]:focus{border-color:var(--teal)}.auth-message{color:var(--teal);background:var(--teal-light);border-radius:var(--radius);padding:8px;font-size:13px}.auth-message-error{color:var(--red);background:#fef2f2}.auth-close-btn{color:var(--gray-500);cursor:pointer;background:0 0;border:none;margin-top:12px;padding:6px;font-size:13px}.header-separator{background:var(--gray-300);width:1px;height:20px;margin:0 2px}.btn-render{background:linear-gradient(135deg, var(--teal) 0%, #1a9e8f 50%, var(--teal-dark) 100%);color:var(--white);letter-spacing:.04em;cursor:pointer;border:none;border-radius:20px;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:700;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #25878c4d}.btn-render:before{content:"";background:linear-gradient(90deg,#0000,#ffffff26,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.btn-render:hover:not(:disabled):before{left:100%}.btn-render:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #25878c66}.btn-render:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #25878c4d}.btn-render:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-render-active{background:linear-gradient(135deg, var(--gold) 0%, #c9a54e 100%);animation:2s ease-in-out infinite renderPulse;box-shadow:0 2px 12px #d1b26b66}.btn-render-success{background:linear-gradient(135deg,#10b981 0%,#059669 100%);box-shadow:0 2px 12px #10b98166}.render-wrapper{z-index:20;position:relative}.render-dropdown{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100;min-width:180px;margin-top:4px;position:absolute;top:100%;right:0;overflow:hidden}.render-dropdown button{cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 14px;transition:background .15s;display:flex}.render-dropdown button:hover{background:var(--teal-light)}.render-res-label{color:var(--teal);min-width:28px;font-size:14px;font-weight:700}.render-res-detail{color:var(--gray-500);font-size:12px}@keyframes renderPulse{0%,to{box-shadow:0 2px 12px #d1b26b66}50%{box-shadow:0 2px 20px #d1b26bb3}}.render-spinner{border:2px solid #ffffff4d;border-top-color:var(--white);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}.render-error-toast{border:1px solid var(--red);color:var(--red);border-radius:var(--radius);z-index:1000;box-shadow:var(--shadow-lg);background:#fef2f2;align-items:center;gap:12px;padding:12px 16px;font-size:13px;display:flex;position:fixed;bottom:20px;right:20px}.render-error-toast button{color:var(--red);cursor:pointer;background:0 0;border:none;font-size:16px}.renders-tab{padding:16px 0}.renders-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.renders-tab-empty,.renders-tab-loading{color:var(--gray-500);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.renders-tab-empty p{font-size:14px}.render-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:transform .2s;overflow:hidden}.render-card:hover{transform:translateY(-2px)}.render-card-image{aspect-ratio:16/9;background:var(--gray-100);overflow:hidden}.render-card-image img{object-fit:cover;width:100%;height:100%}.render-card-processing,.render-card-failed{width:100%;height:100%;color:var(--gray-500);flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:13px;display:flex}.render-spinner-large{border:3px solid var(--gray-200);border-top-color:var(--teal);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.render-attempt{color:var(--gray-500);font-size:11px}.render-card-info{padding:12px}.render-card-meta{color:var(--gray-500);justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.render-card-model{font-weight:500}.render-card-actions{gap:8px;display:flex}.render-download-btn,.render-retry-btn,.render-delete-btn{border:1px solid var(--gray-300);border-radius:var(--radius);background:var(--white);color:var(--gray-500);cursor:pointer;align-items:center;padding:4px 8px;display:flex}.render-download-btn:hover{color:var(--teal);border-color:var(--teal)}.render-retry-btn:hover{color:var(--gold);border-color:var(--gold)}.render-delete-btn:hover{color:var(--red);border-color:var(--red)}.export-separator{background:var(--gray-200);height:1px;margin:4px 0}.render-eye-btn{z-index:50;color:#d1b26b;cursor:pointer;width:44px;height:44px;box-shadow:none;background:#f7f5f0;border:1.5px solid #d1b26b;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.render-eye-btn:hover{color:#fff;background:#d1b26bd9;border-color:#d1b26b;transform:scale(1.1)}.format-btn:hover:not(:disabled){color:#fff;background:#d1b26bd9;border-color:#d1b26b;transform:scale(1.1)}.format-btn:disabled{cursor:not-allowed;opacity:.45}.render-eye-active{color:#fff;background:#d1b26b;border-color:#d1b26b;box-shadow:0 2px 16px #d1b26b80}.render-preview-overlay{z-index:40;cursor:pointer;background:#f7f5f0;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}[data-theme=dark] .render-preview-overlay{background:#080b10}.render-preview-image{object-fit:contain;max-width:100%;max-height:100%}.render-preview-label{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--white);background:#132c3cb3;border-radius:20px;flex-direction:column;align-items:center;gap:2px;padding:8px 20px;font-size:13px;font-weight:600;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.render-preview-hint{opacity:.7;font-size:11px;font-weight:400}.crop-dialog-overlay{z-index:1100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#080c12ad;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.crop-dialog{background:linear-gradient(#fffdfaf7 0%,#f7f5f0fa 100%);border:1px solid #d1b26b47;border-radius:28px;flex-direction:column;width:min(1040px,100%);max-height:min(900px,100vh - 48px);display:flex;overflow:hidden;box-shadow:0 24px 60px #00000047}.crop-dialog-header,.crop-dialog-footer{justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex}.crop-dialog-header{border-bottom:1px solid #d1b26b2e}.crop-dialog-header h2{color:var(--navy);margin:0;font-size:20px}.crop-dialog-close{width:40px;height:40px;color:var(--navy);cursor:pointer;background:#132c3c0f;border:none;border-radius:999px;font-size:26px;line-height:1}.crop-dialog-body{flex:1;grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);min-height:0;display:grid}.crop-dialog-cropper{background:radial-gradient(circle at 0 0,#d1b26b29 0%,#0000 38%),linear-gradient(#ffffffb3 0%,#f7f5f033 100%);flex-direction:column;min-height:540px;padding:24px;display:flex}.room-cropper{background:linear-gradient(135deg,#132c3ceb 0%,#25878cc2 100%);border-radius:20px;flex:1;width:100%;min-height:492px;overflow:hidden}.crop-dialog-loading{height:100%;min-height:492px;color:var(--navy);letter-spacing:.04em;background:#132c3c14;border-radius:20px;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.crop-dialog-controls{background:#ffffff85;border-left:1px solid #d1b26b29;flex-direction:column;gap:24px;padding:24px;display:flex}.crop-dialog-ratios{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.crop-dialog-mode-toggle{min-height:48px;color:var(--navy);cursor:pointer;background:#ffffffc7;border:1px solid #132c3c1f;border-radius:999px;justify-content:center;align-items:center;gap:10px;padding:0 16px;font-size:14px;font-weight:700;transition:all .18s;display:inline-flex}.crop-dialog-mode-toggle:hover:not(:disabled){color:#b4872d;border-color:#d1b26b94}.crop-dialog-mode-toggle-fit{color:#b4872d;background:linear-gradient(#fffaf0fa 0%,#f8eed2e6 100%);border-color:#d1b26b9e}.crop-dialog-mode-toggle:disabled{opacity:.5;cursor:not-allowed}.crop-dialog-ratio{min-height:46px;color:var(--navy);cursor:pointer;background:#ffffffb8;border:1px solid #132c3c1f;border-radius:14px;padding:10px 12px;font-size:14px;font-weight:600;transition:all .18s}.crop-dialog-ratio:hover:not(:disabled),.crop-dialog-ratio-active{color:#b4872d;background:linear-gradient(#fffaf0fa 0%,#f8eed2e6 100%);border-color:#d1b26b9e}.crop-dialog-ratio:disabled{opacity:.5;cursor:not-allowed}.crop-dialog-zoom{color:var(--navy);flex-direction:column;gap:12px;font-size:14px;font-weight:600;display:flex}.crop-dialog-zoom input[type=range]{accent-color:#d1b26b;width:100%}.crop-dialog-zoom strong{color:#b4872d;font-size:22px}.crop-dialog-error{color:#b42318;margin:0;font-size:13px;line-height:1.5}.crop-dialog-footer{border-top:1px solid #d1b26b2e}.crop-dialog-cancel,.crop-dialog-confirm{cursor:pointer;border-radius:999px;min-width:140px;min-height:46px;padding:0 18px;font-size:14px;font-weight:700}.crop-dialog-cancel{color:var(--navy);background:0 0;border:1px solid #132c3c1f}.crop-dialog-confirm{color:#fff;background:linear-gradient(#dfc58c 0%,#c59e4a 100%);border:1px solid #d1b26b}.crop-dialog-cancel:disabled,.crop-dialog-confirm:disabled{opacity:.55;cursor:wait}.room-cropper .advanced-cropper-background,.room-cropper .advanced-cropper-wrapper{background:0 0}.room-cropper-fit{background:#f7f5f0}.room-cropper .advanced-cropper-stencil-overlay{border-radius:18px}.room-cropper .advanced-cropper-rectangle-stencil{border:2px solid #fff8e6f2;box-shadow:0 0 0 9999px #080c127a}.room-cropper-fit .advanced-cropper-rectangle-stencil{box-shadow:0 0 0 9999px #f7f5f0ad}[data-theme=dark] .room-cropper-fit{background:#080b10}[data-theme=dark] .room-cropper-fit .advanced-cropper-rectangle-stencil{box-shadow:0 0 0 9999px #080b10ad}@media (width<=640px){.render-eye-btn{width:38px;height:38px;top:8px;right:8px}.render-eye-btn svg{width:18px;height:18px}.format-btn{width:38px;height:38px;top:54px;right:8px}.render-preview-label{padding:6px 16px;font-size:12px;bottom:12px}.crop-dialog-overlay{padding:0}.crop-dialog{border-radius:0;width:100%;height:100dvh;max-height:none}.crop-dialog-body{flex-direction:column;display:flex}.crop-dialog-cropper{flex:1;min-height:0;padding:16px}.room-cropper,.crop-dialog-loading{min-height:min(56vh,420px)}.crop-dialog-controls{border-top:1px solid #d1b26b29;border-left:none;gap:16px;padding:18px 16px 22px}.crop-dialog-ratios{padding-bottom:4px;display:flex;overflow-x:auto}.crop-dialog-ratio{flex:none;min-width:78px}.crop-dialog-header,.crop-dialog-footer{padding:16px}.crop-dialog-footer{flex-direction:column-reverse;align-items:stretch;gap:12px}.crop-dialog-cancel,.crop-dialog-confirm{width:100%}}.format-btn{z-index:50;color:#d1b26b;cursor:pointer;width:44px;height:44px;box-shadow:none;background:#f7f5f0;border:1.5px solid #d1b26b;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:64px;right:12px}.format-btn:hover{color:#fff;background:#d1b26bd9;border-color:#d1b26b;transform:scale(1.1)}.format-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}@media (width<=640px){.format-btn{width:38px;height:38px;top:54px;right:8px}.format-btn svg{width:18px;height:18px}}[data-theme=dark] .format-btn{color:#d1b26b!important;background:#0c0e16d9!important;border:2px solid #d1b26b4d!important}[data-theme=dark] .format-btn:hover{color:#fff!important;background:#d1b26be6!important;border-color:#d1b26b!important}.crop-dialog-overlay{z-index:9000;-webkit-backdrop-filter:blur(12px);background:#132c3c99;justify-content:center;align-items:center;animation:.25s ease-out cropFadeIn;display:flex;position:fixed;inset:0}@keyframes cropFadeIn{0%{opacity:0}to{opacity:1}}.crop-dialog{background:var(--bg-card);box-shadow:0 24px 80px #00000040, 0 0 0 1px var(--border);border-radius:16px;flex-direction:column;width:min(680px,100vw - 32px);max-height:calc(100vh - 48px);animation:.3s cubic-bezier(.16,1,.3,1) cropSlideUp;display:flex;overflow:hidden}@keyframes cropSlideUp{0%{opacity:0;transform:translateY(24px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.crop-dialog-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.crop-dialog-header h2{letter-spacing:.5px;text-transform:uppercase;color:var(--text);margin:0;font-size:15px;font-weight:600}.crop-dialog-close{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:20px;transition:all .15s;display:flex}.crop-dialog-close:hover{background:var(--gray-100);color:var(--text)}.crop-dialog-body{flex-direction:column;flex:1;padding:0;display:flex;overflow:hidden}.crop-dialog-cropper{background:#f7f5f0;flex:1;min-height:280px;max-height:50vh;position:relative;overflow:hidden}[data-theme=dark] .crop-dialog-cropper{background:#080b10}.crop-dialog-cropper .advanced-cropper{height:100%!important}.crop-dialog-cropper .advanced-cropper__background{background:#f7f5f0!important}[data-theme=dark] .crop-dialog-cropper .advanced-cropper__background{background:#080b10!important}.crop-dialog-cropper .advanced-cropper__foreground{background:#132c3c73!important}[data-theme=dark] .crop-dialog-cropper .advanced-cropper__foreground{background:#0000008c!important}.crop-dialog-cropper .advanced-cropper__stencil{border:2px solid #d1b26b99!important}.room-cropper .advanced-cropper__line{border-color:#d1b26b33!important}.crop-dialog-loading{height:280px;color:var(--text-muted);letter-spacing:.3px;justify-content:center;align-items:center;font-size:14px;display:flex}.crop-dialog-error{color:var(--red);text-align:center;margin:0;padding:8px 20px;font-size:13px}.crop-dialog-controls{border-top:1px solid var(--border);flex-direction:column;gap:14px;padding:16px 20px 12px;display:flex}.crop-dialog-mode-toggle{border:1.5px solid var(--gray-300);background:var(--bg-card);color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:20px;align-self:flex-start;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .2s;display:inline-flex}.crop-dialog-mode-toggle:hover{border-color:var(--gold);color:var(--gold)}.crop-dialog-mode-toggle-fit{border-color:var(--gold);background:var(--gold-light);color:var(--gold)}.crop-dialog-ratios{flex-wrap:wrap;gap:6px;display:flex}.crop-dialog-ratio{border:1.5px solid var(--gray-200);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s}.crop-dialog-ratio:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}.crop-dialog-ratio-active{border-color:var(--teal);background:var(--teal);color:#fff;font-weight:600}.crop-dialog-ratio-active:hover{background:var(--teal-dark);border-color:var(--teal-dark);color:#fff}.crop-dialog-zoom{color:var(--text-muted);align-items:center;gap:10px;font-size:13px;display:flex}.crop-dialog-zoom span{letter-spacing:.5px;min-width:36px;font-weight:500}.crop-dialog-zoom input[type=range]{appearance:none;background:var(--gray-200);cursor:pointer;border-radius:2px;outline:none;flex:1;height:4px}.crop-dialog-zoom input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--teal);cursor:grab;border:2px solid #fff;border-radius:50%;width:18px;height:18px;transition:transform .15s;box-shadow:0 1px 4px #00000026}.crop-dialog-zoom input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}.crop-dialog-zoom input[type=range]::-moz-range-thumb{background:var(--teal);cursor:grab;border:2px solid #fff;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 4px #00000026}.crop-dialog-zoom strong{color:var(--text);text-align:right;font-variant-numeric:tabular-nums;min-width:44px;font-weight:600}.crop-dialog-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:12px 20px 16px;display:flex}.crop-dialog-cancel{border:1.5px solid var(--gray-200);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .15s}.crop-dialog-cancel:hover{border-color:var(--gray-300);background:var(--gray-100);color:var(--text)}.crop-dialog-confirm{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .2s;box-shadow:0 2px 8px #25878c4d}.crop-dialog-confirm:hover{background:var(--teal-dark);transform:translateY(-1px);box-shadow:0 4px 16px #25878c66}.crop-dialog-confirm:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}@media (width<=640px){.crop-dialog{border-radius:0;width:100vw;height:100vh;max-height:100vh;animation:.3s cubic-bezier(.16,1,.3,1) cropSlideUpMobile}@keyframes cropSlideUpMobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.crop-dialog-header{padding:12px 16px 10px}.crop-dialog-header h2{font-size:14px}.crop-dialog-cropper{min-height:220px;max-height:45vh}.crop-dialog-controls{gap:10px;padding:12px 16px 10px}.crop-dialog-ratios{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:6px;padding-bottom:4px;overflow-x:auto}.crop-dialog-ratios::-webkit-scrollbar{display:none}.crop-dialog-ratio{flex-shrink:0;padding:8px 16px;font-size:14px}.crop-dialog-zoom input[type=range]{height:6px}.crop-dialog-zoom input[type=range]::-webkit-slider-thumb{width:22px;height:22px}.crop-dialog-footer{padding:12px 16px calc(env(safe-area-inset-bottom,8px) + 12px);gap:8px}.crop-dialog-cancel,.crop-dialog-confirm{text-align:center;flex:1;padding:12px 16px;font-size:15px}}[data-theme=dark] .crop-dialog-overlay{background:#000000b3}[data-theme=dark] .crop-dialog{background:var(--bg-card);box-shadow:0 24px 80px #0009,0 0 0 1px #ffffff0f}[data-theme=dark] .crop-dialog-close:hover{background:var(--gray-200)}[data-theme=dark] .crop-dialog-mode-toggle{border-color:var(--gray-300);color:var(--text-muted)}[data-theme=dark] .crop-dialog-mode-toggle:hover{border-color:var(--gold);color:var(--gold)}[data-theme=dark] .crop-dialog-mode-toggle-fit{border-color:var(--gold);color:var(--gold);background:#d1b26b1a}[data-theme=dark] .crop-dialog-ratio{border-color:var(--gray-300);color:var(--text-muted)}[data-theme=dark] .crop-dialog-ratio:hover{border-color:var(--teal);background:#25878c1f}[data-theme=dark] .crop-dialog-ratio-active{background:var(--teal);border-color:var(--teal);color:#fff}[data-theme=dark] .crop-dialog-zoom input[type=range]{background:var(--gray-300)}[data-theme=dark] .crop-dialog-zoom input[type=range]::-webkit-slider-thumb{border-color:var(--bg-card)}[data-theme=dark] .crop-dialog-cancel{border-color:var(--gray-300);color:var(--text-muted)}[data-theme=dark] .crop-dialog-cancel:hover{background:var(--gray-200);color:var(--text)}[data-theme=dark] .crop-dialog-confirm{box-shadow:0 2px 12px #25878c66}.spinner{border:3px solid var(--gray-200);border-top-color:var(--teal);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{z-index:9999;flex-direction:column-reverse;gap:8px;max-width:380px;display:flex;position:fixed;bottom:24px;right:24px}.toast{color:#fff;border-radius:10px;align-items:center;gap:10px;padding:12px 16px;font-size:14px;font-weight:500;animation:.2s toast-in;display:flex;box-shadow:0 4px 16px #0000002e}.toast-success{background:#16a34a}.toast-error{background:#dc2626}.toast-warning{background:#ea580c}.toast-info{background:var(--teal)}.toast-message{flex:1}.toast-close{color:#fffc;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:20px;line-height:1}.toast-close:hover{color:#fff}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=600px){.toast-container{max-width:none;bottom:16px;left:16px;right:16px}}.skeleton{background:linear-gradient(90deg,#e8e8e8 25%,#f4f4f4 50%,#e8e8e8 75%) 0 0/200% 100%;animation:1.5s infinite skeleton-pulse}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{pointer-events:none;border:none}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;max-width:440px;margin:0 auto;padding:64px 24px;display:flex}.empty-state-icon{opacity:.3;margin-bottom:16px;font-size:56px}.empty-state-title{color:var(--navy);margin-bottom:8px;font-size:20px;font-weight:600}.empty-state-desc{color:#888;margin-bottom:8px;font-size:14px;line-height:1.6}.empty-state-steps{flex-wrap:wrap;justify-content:center;gap:24px;margin:24px 0;display:flex}.empty-state-step{color:#666;flex-direction:column;align-items:center;gap:6px;font-size:13px;display:flex}.empty-state-step-num{background:var(--teal);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.empty-state-cta{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:12px;margin-top:16px;padding:14px 32px;font-size:16px;font-weight:600;transition:background .15s,transform .15s}.empty-state-cta:hover{background:#1e7176;transform:scale(1.03)}.empty-state-formats{color:#aaa;margin-top:8px;font-size:12px}.dropdown-animated{animation:.15s dropdown-enter}@keyframes dropdown-enter{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.render-progress-bar{z-index:20;background:#25878c26;height:3px;position:absolute;top:48px;left:0;right:0;overflow:hidden}.render-progress-bar:after{content:"";background:linear-gradient(90deg, transparent, var(--teal), transparent);width:50%;height:100%;animation:1.2s infinite progress-slide;position:absolute;top:0;left:-50%}@keyframes progress-slide{0%{left:-50%}to{left:100%}}.render-status-text{color:var(--teal);z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffd9;border-radius:16px;padding:4px 16px;font-size:13px;font-weight:500;animation:2s infinite pulse-opacity;position:absolute;top:56px;left:50%;transform:translate(-50%)}@keyframes pulse-opacity{0%,to{opacity:1}50%{opacity:.5}}.card-badge-render{z-index:2;background:#16a34a;border:2px solid #fff;border-radius:50%;width:10px;height:10px;position:absolute;top:8px;right:8px}.card-badge-count{color:#fff;z-index:2;background:#0000008c;border-radius:3px;padding:1px 5px;font-size:10px;font-weight:700;line-height:1.4;position:absolute;bottom:6px;left:6px}.render-resolution-badge{background:var(--teal);color:#fff;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700;display:inline-block}.render-status-badge{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.render-status-completed{color:#166534;background:#dcfce7}.render-status-processing{color:#1e40af;background:#dbeafe;animation:2s infinite pulse-opacity}.render-status-failed{color:#991b1b;background:#fee2e2}.gallery-card{transition:transform .2s,box-shadow .2s}.gallery-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001f}.btn-render:not(.btn-render-active):after{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(90deg,#0000,#ffffff26,#0000);width:100%;height:100%;animation:3s infinite btn-shimmer;position:absolute;top:0;left:-100%}@keyframes btn-shimmer{0%{left:-100%}30%{left:100%}to{left:100%}}:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.artworks-carousel::-webkit-scrollbar{width:6px;height:6px}.artworks-carousel::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.artworks-carousel::-webkit-scrollbar-track{background:0 0}.gallery-grid{scroll-behavior:smooth}.before-after-slider{z-index:15;cursor:ew-resize;touch-action:none;position:absolute;inset:0;overflow:hidden}.before-after-clip{position:absolute;top:0;bottom:0;left:0;overflow:hidden}.before-after-clip img{object-fit:contain;width:100%;height:100%;position:absolute;top:0;left:0}.before-after-handle{background:var(--teal);z-index:2;pointer-events:none;width:3px;position:absolute;top:0;bottom:0}.before-after-grip{background:var(--teal);color:#fff;pointer-events:auto;border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #0000004d}.login-error{color:#dc2626;text-align:center;margin-top:8px;font-size:13px}.login-forgot{text-align:center;color:#aaa;opacity:.5;pointer-events:none;margin-top:12px;font-size:12px;display:block}.upload-dropzone-active{border:2px dashed var(--teal)!important;background:#25878c0d!important}.upload-dropzone-text{color:var(--teal);font-size:13px;font-weight:500}.profile-wrapper{z-index:30;position:relative}.profile-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:8px;align-items:center;gap:6px;padding:6px 8px;transition:color .15s,background .15s;display:flex}.profile-btn:hover{color:var(--text);background:var(--gray-100)}.profile-email{text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:12px;overflow:hidden}.profile-dropdown{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:200;border-radius:10px;min-width:200px;margin-top:6px;position:absolute;top:100%;right:0;overflow:hidden}.profile-dropdown-email{color:var(--text-muted);border-bottom:1px solid var(--border);padding:12px 14px 8px;font-size:12px}.profile-dropdown-item{cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;align-items:center;gap:10px;padding:10px 14px;font-size:13px;transition:background .15s;display:flex}.profile-dropdown-item:hover{background:var(--gray-100)}.profile-signout{border-top:1px solid var(--border);color:var(--red)}body,.app{background:var(--bg);color:var(--text)}.gallery-page{background:var(--bg)}.gallery-card{background:var(--bg-card);border:1px solid var(--border)}.gallery-card-name{color:var(--text)}.gallery-header{background:var(--bg)}.search-input{background:var(--bg-input);color:var(--text);border-color:var(--border)}.editor-header{background:var(--bg-panel);border-color:var(--border)}.panel,.artworks-panel{background:var(--bg-panel)}.artwork-card{background:var(--bg-card);border-color:var(--border)}.bottom-tabs{background:var(--bg-panel);border-color:var(--border)}.gallery-card-dropdown,.header-dropdown,.export-dropdown,.render-dropdown{background:var(--bg-card);border:1px solid var(--border)}.gallery-card-dropdown button,.header-dropdown button,.export-dropdown button{color:var(--text)}.gallery-card-dropdown button:hover,.header-dropdown button:hover,.export-dropdown button:hover{background:var(--gray-100)}.login-card{background:var(--bg-card)}.login-screen{background:var(--bg)}.btn-save,.btn-export{color:var(--text);border-color:var(--border)}.toast{border:1px solid var(--border)}.empty-state-title{color:var(--text)}.render-status-text{background:var(--bg-card);color:var(--teal)}.editor-canvas-area{background:var(--gray-100)}.editor-page{background:var(--bg)}.panel-title{color:var(--teal)}.panel-hint,.panel-empty{color:var(--text-muted)}.artwork-card{background:var(--bg-card)}.artwork-card-name{color:var(--text)}.artwork-card-size{color:var(--text-faint)}.artwork-upload-btn{border-color:var(--border);color:var(--text-muted)}.btn-save,.btn-export{background:var(--bg-card);border-color:var(--border);color:var(--text)}.btn-icon,.title-text{color:var(--text)}[data-theme=dark] body,[data-theme=dark] .app,[data-theme=dark] .gallery-page,[data-theme=dark] .editor-page{background:linear-gradient(165deg,#0a0f14 0%,#0d1219 40%,#0f151c 70%,#0a1015 100%)}[data-theme=dark] .gallery-card{background:#12181ed9;border:1px solid #25878c0f;box-shadow:0 2px 10px #00000059}[data-theme=dark] .gallery-card:hover{border-color:#25878c40;box-shadow:0 6px 28px #00000073,0 0 0 1px #25878c1f}[data-theme=dark] .gallery-header{-webkit-backdrop-filter:blur(16px);background:#0a0f14e0;border-bottom:1px solid #25878c14}[data-theme=dark] .gallery-tab{color:#e4e6eb80}[data-theme=dark] .search-input{color:#e4e6eb;background:#ffffff0a;border:1px solid #ffffff0f}[data-theme=dark] .search-input::placeholder{color:#ffffff40}[data-theme=dark] .search-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #25878c1f}[data-theme=dark] .btn-upload-interior{background:var(--teal);color:#fff}[data-theme=dark] .editor-header{-webkit-backdrop-filter:blur(16px);background:#0c1016eb;border-bottom:1px solid #25878c0f}[data-theme=dark] .editor-canvas-area{background:#080b10}[data-theme=dark] .artworks-panel,[data-theme=dark] .panel{background:#0e1218f2;border-top:1px solid #25878c0f}[data-theme=dark] .artwork-card{background:#ffffff08;border:1px solid #ffffff0d}[data-theme=dark] .artwork-card:hover,[data-theme=dark] .artwork-card-active{background:#25878c0f;border-color:#25878c59}[data-theme=dark] .gallery-card-dropdown,[data-theme=dark] .header-dropdown,[data-theme=dark] .export-dropdown,[data-theme=dark] .render-dropdown,[data-theme=dark] .profile-dropdown{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#12161ef5;border:1px solid #25878c1a;box-shadow:0 12px 40px #0009}[data-theme=dark] .gallery-card-dropdown button,[data-theme=dark] .header-dropdown button,[data-theme=dark] .export-dropdown button{color:#dde0e6}[data-theme=dark] .gallery-card-dropdown button:hover,[data-theme=dark] .header-dropdown button:hover,[data-theme=dark] .export-dropdown button:hover,[data-theme=dark] .profile-dropdown-item:hover{background:#25878c14}[data-theme=dark] .btn-save,[data-theme=dark] .btn-export{color:#c0c4cc;background:#ffffff0a;border:1px solid #ffffff14}[data-theme=dark] .btn-save:hover,[data-theme=dark] .btn-export:hover{color:#e4e6eb;background:#25878c1a;border-color:#25878c33}[data-theme=dark] .login-screen{background:linear-gradient(135deg,#080c12 0%,#0c1218 35%,#0e161e 65%,#101a22 100%)}[data-theme=dark] .login-card{-webkit-backdrop-filter:blur(24px);background:#10161cd9;border:1px solid #25878c1a;box-shadow:0 20px 60px #00000080,0 0 80px #25878c08}[data-theme=dark] .login-field input{color:#e4e6eb;background:#ffffff0a;border:1px solid #ffffff14}[data-theme=dark] .login-field input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #25878c26}[data-theme=dark] .login-title{color:#e4e6eb}[data-theme=dark] .login-subtitle{color:#e4e6eb80}[data-theme=dark] .login-footer{color:#e4e6eb4d}[data-theme=dark] .login-forgot{color:#e4e6eb33}[data-theme=dark] .toast{border:1px solid #ffffff0f;box-shadow:0 8px 32px #00000080}[data-theme=dark] .render-status-text{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0e1218eb}[data-theme=dark] .empty-state-cta{box-shadow:0 4px 20px #25878c40}[data-theme=dark] .empty-state-title{color:#e4e6eb}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#ffffff08 25%,#ffffff0f 50%,#ffffff08 75%) 0 0/200% 100%}[data-theme=dark] .gallery-card-delete-btn{background:#0000008c}[data-theme=dark] .bottom-tabs,[data-theme=dark] .bottom-tab-bar{background:#0c1016f2;border-top:1px solid #25878c0f}[data-theme=dark] .render-card{background:#12181ed9;border:1px solid #ffffff0d}[data-theme=dark] .btn-render{background:linear-gradient(135deg, var(--teal) 0%, var(--teal-dark) 100%);box-shadow:0 4px 16px #25878c40}[data-theme=dark] .gallery-card-delete-btn{color:#d1b26b!important;background:#0c0e16cc!important}[data-theme=dark] .gallery-card-delete-btn:hover{color:#fff!important;background:#d1b26b!important}[data-theme=dark] .artwork-card-delete{color:#d1b26b!important;background:#0c0e16cc!important}[data-theme=dark] .artwork-card-delete:hover{color:#fff!important;background:#d1b26b!important}[data-theme=dark] .render-eye-btn{color:#d1b26b!important;background:#0c0e16d9!important;border:2px solid #d1b26b4d!important}[data-theme=dark] .render-eye-btn:hover{color:#fff!important;background:#d1b26be6!important;border-color:#d1b26b!important}[data-theme=dark] .render-eye-active{color:#fff!important;background:#d1b26b!important;border-color:#d1b26b!important}[data-theme=dark] .btn-render{box-shadow:0 4px 16px #d1b26b4d;color:#0c0e16!important;background:linear-gradient(135deg,#d1b26b 0%,#b89a52 100%)!important}[data-theme=dark] .btn-render:hover{box-shadow:0 6px 24px #d1b26b66}[data-theme=dark] .btn-render:disabled,[data-theme=dark] .btn-render-active{color:#ffffffb3!important;background:linear-gradient(135deg,#8a7a4a 0%,#6e6340 100%)!important}[data-theme=dark] .artwork-upload-btn{background:#0c0e16b3!important;border:1px dashed #d1b26b4d!important}[data-theme=dark] .artwork-upload-btn:hover{background:#d1b26b14!important;border-color:#d1b26b80!important}[data-theme=dark] .upload-icon-wrapper{background:0 0!important}[data-theme=dark] .artwork-upload-btn svg,[data-theme=dark] .artwork-upload-btn .upload-icon-wrapper svg{stroke:#d1b26b!important}[data-theme=dark] .artwork-upload-btn .artwork-card-name{color:#e4e6eb!important}[data-theme=dark] .artwork-upload-btn .artwork-card-size{color:#e4e6eb80!important}[data-theme=dark] .gallery-card-menu-btn{color:#e4e6eb66}[data-theme=dark] .gallery-card-menu-btn:hover{color:#d1b26b;background:#d1b26b14}[data-theme=dark] .card-badge-count{color:#0c0e16;background:#d1b26bcc}[data-theme=dark] .profile-btn:hover{color:#d1b26b}[data-theme=dark] .gallery-tab-active{color:#d1b26b;border-color:#d1b26b}[data-theme=dark] .panel-title,[data-theme=dark] .bottom-tab-active,[data-theme=dark] [class*=tab-btn-active]{color:#d1b26b}
