*{box-sizing:border-box}:root{color:#242a31;background:#f4f6f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;background:#f4f6f8}button,select,input{font:inherit}button{border:0}button:disabled,select:disabled{cursor:not-allowed;opacity:.52}#root{min-height:100vh}.app-shell{min-height:100vh;background:#f4f6f8}.site-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:24px;min-height:64px;padding:0 16px;color:#fff;background:#2f3c48}.brand-lockup{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{display:flex;align-items:center;justify-content:center;flex:0 0 auto;width:42px;height:42px;color:#fff;background:#4c8fe8;border-radius:8px;font-size:15px;font-weight:800;letter-spacing:0}.brand-copy{display:flex;flex-direction:column;min-width:0}.brand-copy strong{overflow:hidden;font-size:20px;line-height:1.15;text-overflow:ellipsis;white-space:nowrap}.brand-copy span{overflow:hidden;color:#ffffffad;font-size:12px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.header-actions{display:flex;align-items:center;gap:10px}.header-actions select,.control-row select{min-height:34px;padding:0 10px;color:#27313b;background:#fff;border:1px solid #d9dee5;border-radius:6px;outline:none}.workspace-shell{display:grid;grid-template-columns:minmax(0,1fr) 388px;gap:24px;min-height:calc(100vh - 64px);padding:24px 16px}.content-panel{display:flex;flex-direction:column;min-width:0}h1{margin:8px 0 28px;color:#2e3338;font-size:22px;line-height:1.25;letter-spacing:0}.upload-surface{position:relative;flex:1 1 auto;min-height:560px;overflow:hidden;background:#fff;border:1px solid #e4e7eb;border-radius:8px}.upload-surface.empty{display:flex;align-items:center;justify-content:center}.upload-surface.has-image{background:#fff}.file-input{display:none}.empty-upload{position:relative;z-index:10;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;color:#b4bac2;text-align:center}.upload-surface.empty .scene-canvas{opacity:0;pointer-events:none}.empty-upload p{margin:0;color:#c0c5cc;font-size:14px;font-weight:700}.upload-symbol{position:relative;width:76px;height:64px}.upload-symbol:before,.upload-symbol:after,.upload-symbol span{position:absolute;border-radius:8px;content:""}.upload-symbol:before{right:10px;bottom:4px;width:60px;height:46px;background:#aeb5bd;transform:rotate(-7deg)}.upload-symbol:after{right:0;bottom:0;width:60px;height:46px;background:#cfd4da}.upload-symbol span{right:9px;bottom:7px;z-index:1;width:38px;height:28px;background:radial-gradient(circle at 24% 20%,#828b94 0 5px,transparent 6px),linear-gradient(135deg,transparent 0 48%,#8e98a3 49% 100%);border-radius:6px}.outline-pill-button{width:154px;min-height:48px;color:#858c95;background:#fff;border:2px solid #b8bdc4;border-radius:999px;cursor:pointer;font-size:16px;font-weight:800}.scene-canvas{position:absolute;top:0;right:0;bottom:0;left:0;display:block;width:100%;height:100%;min-height:560px}.stage-toolbar{position:absolute;top:14px;left:14px;z-index:20;display:flex;align-items:center;gap:8px;max-width:calc(100% - 28px);pointer-events:auto}.text-button{min-height:32px;padding:0 12px;color:#2f3c48;background:#ffffffeb;border:1px solid #dfe4ea;border-radius:6px;cursor:pointer;font-size:13px;font-weight:700;box-shadow:0 8px 18px #26334114}.text-button.danger{color:#d14545}.file-chip{min-width:0;max-width:260px;min-height:32px;padding:7px 10px;overflow:hidden;color:#5d6670;background:#ffffffeb;border:1px solid #dfe4ea;border-radius:6px;font-size:13px;line-height:18px;text-overflow:ellipsis;white-space:nowrap;box-shadow:0 8px 18px #26334114}.result-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:40;display:flex;align-items:center;justify-content:center;background:#fff}.result-layer img{display:block;max-width:100%;max-height:100%;object-fit:contain}.floating-edit-button{position:absolute;bottom:20px;left:50%;min-width:128px;min-height:38px;color:#fff;background:#232a32b8;border-radius:8px;cursor:pointer;font-weight:700;transform:translate(-50%)}.settings-panel{align-self:start;display:flex;flex-direction:column;gap:18px;min-width:0;max-height:calc(100vh - 112px);padding:24px 18px 20px;overflow-y:auto;background:#fff;border-radius:8px;box-shadow:0 12px 28px #26334114}.settings-section{display:flex;flex-direction:column;gap:14px;min-width:0}.settings-section h2{margin:0;color:#2f343a;font-size:16px;line-height:1.35;letter-spacing:0}.segmented-control{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;padding:4px;background:#f4f5f6;border:1px solid #e6e9ed;border-radius:8px}.segmented-control button{min-width:0;min-height:30px;overflow:hidden;color:#2f343a;background:transparent;border-radius:6px;cursor:pointer;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.segmented-control button.selected{color:#fff;background:#2f3c48}.preset-grid{display:grid;gap:10px;min-width:0}.preset-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.preset-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.preset-card{display:flex;align-items:stretch;flex-direction:column;gap:7px;min-width:0;padding:0;color:#20252b;background:transparent;border-radius:8px;cursor:pointer;font-size:13px;line-height:1.25}.preset-card>span:last-child{min-height:18px;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.preset-card.active>span:last-child{color:#1d6fe3;font-weight:800}.preset-thumb{position:relative;display:block;width:100%;aspect-ratio:1 / .86;overflow:hidden;background:#eef1f4;border:2px solid transparent;border-radius:8px}.preset-card.active .preset-thumb{border-color:#2f80ed}.preset-thumb img{display:block;width:100%;height:100%;object-fit:cover}.angle-badge{position:absolute;top:50%;left:50%;display:flex;align-items:center;justify-content:center;width:42px;height:28px;color:#fff;background:#232a3285;border-radius:999px;font-size:12px;font-weight:800;transform:translate(-50%,-50%)}.fine-controls{min-width:0;color:#3a4149;border-top:1px solid #eef1f4;border-bottom:1px solid #eef1f4}.fine-controls summary{min-height:42px;padding:12px 0;cursor:pointer;font-size:14px;font-weight:800}.control-stack{display:flex;flex-direction:column;gap:14px;min-width:0;padding-bottom:16px}.control-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px}.switch-row{display:inline-flex;align-items:center;gap:9px;color:#3e4650;font-size:14px}.switch-row input{width:18px;height:18px;accent-color:#2f80ed}.primary-button,.ghost-button,.icon-button{min-height:36px;border-radius:6px;cursor:pointer;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.primary-button{padding:0 16px;color:#fff;background:#2f3c48;font-weight:800}.primary-button:hover:not(:disabled),.ghost-button:hover:not(:disabled),.icon-button:hover:not(:disabled),.outline-pill-button:hover:not(:disabled),.preset-card:hover:not(:disabled) .preset-thumb,.text-button:hover:not(:disabled){transform:translateY(-1px)}.ghost-button{padding:0 14px;color:#2f3c48;background:transparent;border:1px solid #cfd6dd}.icon-button{width:36px;color:#2f3c48;background:#fff;border:1px solid #cfd6dd;font-size:18px;line-height:1}.full-width{width:100%}.control-group{display:flex;flex-direction:column;gap:8px;min-width:0}.control-heading{display:flex;align-items:baseline;justify-content:space-between;gap:12px;min-width:0}.control-heading span{overflow:hidden;color:#626b76;font-size:14px;text-overflow:ellipsis;white-space:nowrap}.control-heading strong{flex-shrink:0;color:#2f80ed;font-size:14px}.control-row{display:grid;grid-template-columns:minmax(128px,.86fr) minmax(120px,1fr);gap:10px;align-items:center;min-width:0}.control-row select,.control-row input[type=range]{width:100%;min-width:0}.control-row input[type=range]{accent-color:#2f80ed}.settings-footer{display:flex;flex-direction:column;gap:14px;margin-top:auto;padding-top:4px}.status-line{display:flex;flex-direction:column;gap:5px;min-width:0;color:#6c747e;font-size:13px;line-height:1.45;word-break:break-word}.status-line strong{color:#2f343a;font-size:13px}@media(max-width:1180px){.workspace-shell{grid-template-columns:minmax(0,1fr) 360px}}@media(max-width:900px){.workspace-shell{grid-template-columns:1fr;gap:18px}.settings-panel{max-height:none}.upload-surface,.scene-canvas{min-height:58vh}}@media(max-width:560px){.site-header{gap:12px;padding:10px 12px}.brand-mark{width:36px;height:36px}.brand-copy strong{font-size:17px}.header-actions select{max-width:106px}.workspace-shell{padding:14px 12px 18px}h1{margin:4px 0 14px;font-size:19px}.settings-panel{padding:18px 14px}.preset-grid.four,.preset-grid.three{grid-template-columns:repeat(2,minmax(0,1fr))}.stage-toolbar{align-items:flex-start;flex-wrap:wrap}.file-chip{max-width:100%}.control-row{grid-template-columns:1fr}}
