:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f7f3ea;--surface:#fffdf8;--panel:#f1eadf;--panel-soft:#fbf8f1;--line:#ded5c7;--line-strong:#b7a88f;--text:#24211d;--muted:#777067;--accent:#b99b5f;--accent-strong:#755c32;--graphite:#312d28;--snap:#858a4d;--danger:#9e3f38;--shadow:0 22px 70px #3f352724;font-family:Avenir Next,Avenir,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{background:var(--bg);width:100%;min-width:0;min-height:100%;margin:0}body{min-width:320px;overflow:hidden}button,input{font:inherit}button{border:0}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;padding:0;position:absolute;overflow:hidden}.app-shell{width:100vw;min-width:0;height:100vh;min-height:100dvh;color:var(--text);background:linear-gradient(180deg, #fffdf8e0 0%, #f7f3eaf5 42%), var(--bg);grid-template-rows:auto 1fr;display:grid}.toolbar{border-bottom:1px solid var(--line);backdrop-filter:blur(18px);background:#fffdf8eb;justify-content:space-between;align-items:center;gap:28px;min-width:0;padding:20px 28px;display:flex}.brand-block{gap:5px;min-width:190px;display:grid}.eyebrow,.panel-label{color:var(--muted);letter-spacing:0;text-transform:uppercase;margin:0;font-size:10px;font-weight:700}h1{color:var(--graphite);letter-spacing:0;margin:0;font-family:Georgia,Times New Roman,serif;font-size:31px;font-weight:500;line-height:.95}.toolbar-controls{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;min-width:0;display:flex}.button,.segmented-control button,.upload-dropzone{color:var(--text);cursor:pointer;border:1px solid #0000;border-radius:6px;transition:transform .15s,border-color .15s,background .15s,color .15s,opacity .15s,box-shadow .15s}.button{white-space:nowrap;min-height:39px;padding:0 15px;font-size:13px;font-weight:700}.button:hover,.segmented-control button:hover,.upload-dropzone:hover{transform:translateY(-1px)}.button:focus-visible,.segmented-control button:focus-visible,.upload-dropzone:focus-visible{outline-offset:2px;outline:2px solid #b99b5f6b}.button:disabled{cursor:not-allowed;opacity:.45;transform:none}.button.primary{background:var(--graphite);color:#fffaf0;border-color:var(--graphite);box-shadow:0 10px 28px #312d2829}.button.primary:hover{background:#211f1c}.button.secondary{border-color:var(--line);color:var(--graphite);background:#fffdf8db}.button.secondary:hover{border-color:var(--line-strong);background:#fff}.button.save{background:var(--accent);color:#1f1b15;border-color:#a88748;box-shadow:0 10px 28px #b99b5f33}.button.save:hover:not(:disabled){background:#c8aa6b}.segmented-control{border:1px solid var(--line);background:#f1eadfb8;border-radius:6px;grid-template-columns:repeat(3,minmax(72px,1fr));gap:3px;height:39px;padding:3px;display:grid}.segmented-control button{color:#696157;background:0 0;min-width:0;padding:0 10px;font-size:12px;font-weight:700}.segmented-control button.active{background:var(--surface);color:var(--graphite);border-color:#b7a88fb3;box-shadow:0 3px 10px #3f352714}.workspace{grid-template-columns:minmax(220px,292px) 1fr;min-width:0;min-height:0;display:grid}.side-panel{border-right:1px solid var(--line);background:linear-gradient(180deg, #fbf8f1f2, #f1eadfd1), var(--panel);flex-direction:column;gap:23px;min-width:0;padding:28px;display:flex}.stats-grid{gap:18px;display:grid}.panel-value{overflow-wrap:anywhere;min-width:0;color:var(--graphite);margin:7px 0 0;font-size:15px;line-height:1.38}.error-message{color:var(--danger);margin:0;font-size:13px;line-height:1.4}.image-stage{background-color:#ece6db;background-image:linear-gradient(#312d280b 1px,#0000 1px),linear-gradient(90deg,#312d280b 1px,#0000 1px);background-size:34px 34px;place-items:center;min-width:0;min-height:0;padding:18px;display:grid;position:relative;overflow:hidden}.snap-toggle{z-index:20;width:auto;min-width:104px;height:38px;color:var(--graphite);cursor:pointer;white-space:nowrap;backdrop-filter:blur(14px);background:#fffdf8db;border:1px solid #b7a88fd1;border-radius:6px;justify-content:center;align-items:center;gap:7px;padding:0 12px;font-size:12px;font-weight:400;line-height:1;transition:background .15s,border-color .15s,color .15s,transform .15s,opacity .15s;display:inline-flex;position:absolute;top:18px;left:18px;box-shadow:0 10px 26px #312d2824}.snap-toggle:hover,.snap-toggle:focus-visible{border-color:var(--accent);background:#fffdf8;transform:translateY(-1px)}.snap-toggle:focus-visible{outline-offset:2px;outline:2px solid #b99b5f6b}.snap-toggle:not(.active){color:#857a6d;opacity:.78}.snap-toggle-icon{flex:none;width:15px;height:15px}.snap-toggle.active .snap-toggle-slash{display:none}.upload-dropzone{aspect-ratio:16/10;background:linear-gradient(180deg, #fffdf8f0, #f7f3eaf0), var(--surface);border:1px dashed var(--line-strong);width:min(560px,100vw - 48px);box-shadow:var(--shadow);align-content:center;place-items:center;gap:9px;display:grid}.upload-dropzone span{color:var(--graphite);font-family:Georgia,Times New Roman,serif;font-size:25px;font-weight:500}.upload-dropzone small{color:var(--muted);font-size:13px}.image-board{box-shadow:var(--shadow);-webkit-user-select:none;user-select:none;touch-action:none;background:#fdfbf6;border:1px solid #312d282e;border-radius:6px;position:relative;overflow:hidden}.source-image{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;inset:0}.crop-frame{cursor:move;touch-action:none;will-change:transform, width, height;background:0 0;border:1px solid #312d28db;min-width:24px;min-height:24px;transition:border-color .14s,box-shadow .14s,background .14s;position:absolute;top:0;left:0;container-type:size}.crop-frame:hover{border-color:var(--accent-strong);box-shadow:0 0 0 1px #fffdf8b8,0 0 0 2px #755c3294}.crop-frame.selected{border-color:var(--accent);box-shadow:0 0 0 1px #fffdf8e0,0 0 0 3px #b99b5f9e,0 14px 34px #312d2833}.crop-frame.snapped{border-color:var(--snap);animation:.45s snapPulse;box-shadow:0 0 0 1px #fffdf8e6,0 0 0 3px #858a4d9e,0 0 24px #858a4d38}.frame-number,.frame-aspect,.frame-size{color:#fffaf0;pointer-events:none;background:#312d28d1;border:1px solid #fffdf8b8;border-radius:4px;place-items:center;height:22px;line-height:1;display:grid;position:absolute}.frame-number{min-width:28px;padding:0 7px;font-size:11px;font-weight:800;top:7px;left:7px}.frame-aspect{background:#312d28c2;min-width:34px;padding:0 8px;font-size:10px;font-weight:700;bottom:7px;left:7px}.frame-size{background:#312d28c2;min-width:58px;padding:0 8px;font-size:10px;font-weight:700;bottom:7px;right:7px}.frame-delete{color:#fffaf0;cursor:pointer;background:#312d28d1;border:1px solid #fffdf8b8;border-radius:4px;place-items:center;width:24px;height:22px;padding:0;transition:background .14s,border-color .14s,transform .14s;display:grid;position:absolute;top:7px;right:7px;box-shadow:0 5px 14px #312d2829}.frame-delete:before,.frame-delete:after{content:"";background:currentColor;width:10px;height:1px;position:absolute}.frame-delete:before{transform:rotate(45deg)}.frame-delete:after{transform:rotate(-45deg)}.frame-delete:hover,.frame-delete:focus-visible{background:#755c32e6;border-color:#fffdf8eb;transform:translateY(-1px)}.frame-delete:focus-visible{outline-offset:2px;outline:2px solid #b99b5f6b}@container (width<=106px){.frame-aspect,.frame-size{display:none}}@container (height<=58px){.frame-aspect,.frame-size{display:none}}@container (width<=66px){.frame-number,.frame-delete{display:none}}@container (height<=30px){.frame-number,.frame-delete{display:none}}.thirds{pointer-events:none;background:#fffdf894;position:absolute;box-shadow:0 0 0 1px #312d282e}.thirds.vertical-one,.thirds.vertical-two{width:1px;height:100%;top:0}.thirds.vertical-one{left:33.333%}.thirds.vertical-two{left:66.666%}.thirds.horizontal-one,.thirds.horizontal-two{width:100%;height:1px;left:0}.thirds.horizontal-one{top:33.333%}.thirds.horizontal-two{top:66.666%}.resize-handle{background:#fffdf8;border:1px solid #312d28d1;border-radius:50%;width:10px;height:10px;position:absolute;box-shadow:0 0 0 1px #fffdf8cc,0 4px 10px #312d283d}.resize-handle.nw{cursor:nwse-resize;top:-6px;left:-6px}.resize-handle.n{cursor:ns-resize;top:-6px;left:calc(50% - 5px)}.resize-handle.ne{cursor:nesw-resize;top:-6px;right:-6px}.resize-handle.e{cursor:ew-resize;top:calc(50% - 5px);right:-6px}.resize-handle.se{cursor:nwse-resize;bottom:-6px;right:-6px}.resize-handle.s{cursor:ns-resize;bottom:-6px;left:calc(50% - 5px)}.resize-handle.sw{cursor:nesw-resize;bottom:-6px;left:-6px}.resize-handle.w{cursor:ew-resize;top:calc(50% - 5px);left:-6px}.snap-guide{z-index:9999;background:var(--snap);pointer-events:none;position:absolute;box-shadow:0 0 14px #858a4d75}.snap-guide.vertical{width:2px;transform:translate(-1px)}.snap-guide.horizontal{height:2px;transform:translateY(-1px)}.modal-backdrop{z-index:100;backdrop-filter:blur(10px);background:#312d2847;place-items:center;padding:22px;display:grid;position:fixed;inset:0}.export-modal{background:linear-gradient(180deg, #fffdf8fa, #f7f3eafa), var(--surface);border:1px solid #b7a88fc7;border-radius:8px;width:min(760px,100%);max-height:min(760px,100dvh - 44px);overflow:auto;box-shadow:0 28px 90px #312d2847}.modal-heading,.modal-actions{justify-content:space-between;align-items:center;gap:16px;padding:20px 22px;display:flex}.modal-heading{border-bottom:1px solid var(--line)}.modal-heading h2{color:var(--graphite);margin:5px 0 0;font-family:Georgia,Times New Roman,serif;font-size:24px;font-weight:500;line-height:1}.modal-close{border:1px solid var(--line);width:30px;height:30px;color:var(--graphite);cursor:pointer;background:#fffdf8e0;border-radius:6px;flex:none;padding:0;position:relative}.modal-close:before,.modal-close:after{content:"";background:currentColor;width:12px;height:1px;position:absolute;top:14px;left:8px}.modal-close:before{transform:rotate(45deg)}.modal-close:after{transform:rotate(-45deg)}.export-modal-grid{grid-template-columns:minmax(240px,.9fr) minmax(260px,1.1fr);gap:22px;padding:22px;display:grid}.export-settings{align-content:start;gap:20px;display:grid}.modal-format-control{width:100%;margin-top:8px}.quality-control{gap:12px;display:grid}.quality-control>span,.quality-value{justify-content:space-between;align-items:center;gap:12px;display:flex}.quality-value{color:var(--graphite);font-size:13px}.quality-control input{width:100%;accent-color:var(--accent)}.modal-note{color:var(--muted);margin:8px 0 0;font-size:13px;line-height:1.4}.export-size-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.export-preview{border:1px solid var(--line);background-color:#fffdf8;background-image:linear-gradient(45deg,#312d280f 25%,#0000 25%),linear-gradient(-45deg,#312d280f 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#312d280f 75%),linear-gradient(-45deg,#0000 75%,#312d280f 75%),none;background-position:0 0,0 8px,8px -8px,-8px 0;background-repeat:repeat,repeat,repeat,repeat,repeat;background-size:16px 16px;background-attachment:scroll,scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box,border-box;border-radius:6px;place-items:center;min-height:280px;display:grid;overflow:hidden}.export-preview img{object-fit:contain;max-width:100%;max-height:420px;display:block}.export-preview-empty{color:var(--muted);font-size:13px}.modal-actions{border-top:1px solid var(--line);justify-content:flex-end}@keyframes snapPulse{0%{background:#858a4d33;box-shadow:0 0 0 1px #fffdf8e6,0 0 0 3px #858a4db8,0 0 28px #858a4d47}45%{background:#858a4d1f;box-shadow:0 0 0 1px #fffdf8e6,0 0 0 4px #858a4d85,0 0 30px #858a4d38}to{background:0 0;box-shadow:0 0 0 1px #fffdf8e6,0 0 0 3px #858a4d9e,0 0 24px #858a4d38}}@media (width<=920px){body{overflow:auto}.app-shell{height:auto;min-height:100dvh}.toolbar{flex-direction:column;align-items:stretch;gap:18px;padding:18px}.toolbar-controls{justify-content:flex-start}.workspace{grid-template-rows:auto minmax(420px,1fr);grid-template-columns:1fr}.side-panel{border-right:0;border-bottom:1px solid var(--line);grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 24px;padding:20px 18px;display:grid}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.image-stage{min-height:clamp(420px,62dvh,720px);padding:16px}.snap-toggle{top:14px;left:14px}.export-modal-grid{grid-template-columns:1fr}.export-preview{min-height:240px}}@media (width<=620px){h1{font-size:28px}.brand-block{min-width:0}.toolbar{gap:16px;padding:16px}.toolbar-controls,.button,.segmented-control{width:100%}.button,.segmented-control{min-height:44px}.segmented-control button{min-height:36px}.segmented-control{grid-template-columns:repeat(3,minmax(0,1fr))}.workspace{grid-template-rows:auto minmax(440px,1fr)}.side-panel{grid-template-columns:1fr;gap:16px;padding:18px 16px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.image-stage{min-height:clamp(440px,64dvh,680px);padding:14px}.upload-dropzone{width:min(100%,100vw - 36px);min-height:260px}.modal-backdrop{padding:12px}.modal-heading,.modal-actions,.export-modal-grid{padding:16px}.modal-actions{flex-direction:column;align-items:stretch}.export-size-grid{grid-template-columns:1fr}}@media (width<=380px){.toolbar,.side-panel{padding-left:14px;padding-right:14px}.stats-grid{grid-template-columns:1fr}.image-stage{min-height:430px;padding:12px}}@media (pointer:coarse){.button,.segmented-control{min-height:44px}.resize-handle{width:14px;height:14px}.resize-handle.nw{top:-8px;left:-8px}.resize-handle.n{top:-8px;left:calc(50% - 7px)}.resize-handle.ne{top:-8px;right:-8px}.resize-handle.e{top:calc(50% - 7px);right:-8px}.resize-handle.se{bottom:-8px;right:-8px}.resize-handle.s{bottom:-8px;left:calc(50% - 7px)}.resize-handle.sw{bottom:-8px;left:-8px}.resize-handle.w{top:calc(50% - 7px);left:-8px}}