.app{max-width:760px;margin:0 auto;padding:24px 20px 80px}header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:24px}header h1{font-size:28px;margin:0;letter-spacing:-.02em}main{display:flex;flex-direction:column;gap:20px}.card{background:#fff;border:1px solid #e7e2d9;border-radius:12px;padding:20px}.card h2{margin:0 0 12px;font-size:18px}.dropzone{display:block;position:relative;border:2px dashed #cfcabe;border-radius:10px;padding:28px 16px;text-align:center;background:#fbf8f1;cursor:pointer;transition:border-color .12s,background .12s}.dropzone:hover{border-color:#9c8c5e}.dropzone.drag{border-color:#1d1d1d;background:#f3eede}.dropzone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.dropzone-hint{pointer-events:none;display:flex;flex-direction:column;gap:4px;color:#555;font-size:14px}.dropzone-hint strong{color:#1d1d1d;font-size:15px}input[type=password]{display:block;width:100%;padding:10px 12px;font-size:16px;border:1px solid #d2cfca;border-radius:8px;margin-bottom:12px}button{font-size:15px;padding:10px 16px;border-radius:8px;border:1px solid #d2cfca;background:#fff;cursor:pointer}button:disabled{opacity:.55;cursor:not-allowed}button.primary{background:#1d1d1d;color:#fff;border-color:#1d1d1d}button.ghost{background:transparent}.preview{margin-top:12px;display:flex;flex-direction:column;align-items:flex-start;gap:8px}.preview img{max-width:100%;max-height:360px;border:1px solid #e7e2d9;border-radius:8px}.preview.transparent-bg img{background-image:linear-gradient(45deg,#ddd 25%,transparent 25%),linear-gradient(-45deg,#ddd 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#ddd 75%),linear-gradient(-45deg,transparent 75%,#ddd 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0}.preview .meta{font-size:13px;color:#666}.error{margin-top:12px;background:#fde8e8;color:#8c1f1f;padding:10px 12px;border-radius:8px;font-size:14px;white-space:pre-wrap}.success{margin-top:12px;background:#e6f6ec;color:#1d6a3a;padding:10px 12px;border-radius:8px;font-size:14px}.success a{color:#1d6a3a;text-decoration:underline}.step-actions{display:flex;flex-wrap:wrap;gap:8px}.history-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:12px}.history-header h2{margin:0}.history-note{font-size:12px;color:#888}.history-strip{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px}.history-item{position:relative;flex:0 0 auto;width:140px;display:flex;flex-direction:column;gap:6px}.history-thumb{width:140px;height:140px;padding:0;border:1px solid #e7e2d9;border-radius:8px;background-image:linear-gradient(45deg,#ddd 25%,transparent 25%),linear-gradient(-45deg,#ddd 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#ddd 75%),linear-gradient(-45deg,transparent 75%,#ddd 75%);background-size:12px 12px;background-position:0 0,0 6px,6px -6px,-6px 0;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center}.history-thumb img{max-width:100%;max-height:100%;display:block}.history-meta{font-size:12px;color:#555;line-height:1.3}.history-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-sub{color:#888}.history-delete{position:absolute;top:4px;right:4px;padding:2px 8px;font-size:13px;background:#ffffffd9}.crop-tool{margin-top:12px;display:flex;flex-direction:column;gap:12px}.crop-stage{position:relative;display:inline-block;align-self:flex-start;background:#f0f0f0;border:1px solid #e7e2d9;border-radius:8px;overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none;max-width:100%}.crop-stage img{display:block;max-width:100%;max-height:70vh;height:auto;width:auto;pointer-events:none}.crop-rect{position:absolute;border:2px solid #fff;box-shadow:0 0 0 9999px #0006;cursor:move;box-sizing:border-box}.crop-handle{position:absolute;width:14px;height:14px;background:#fff;border:1px solid #1d1d1d;border-radius:50%;box-sizing:border-box}.crop-handle.nw{top:-8px;left:-8px;cursor:nwse-resize}.crop-handle.ne{top:-8px;right:-8px;cursor:nesw-resize}.crop-handle.sw{bottom:-8px;left:-8px;cursor:nesw-resize}.crop-handle.se{bottom:-8px;right:-8px;cursor:nwse-resize}.crop-info{font-size:13px;color:#666}.paint-editor{margin-top:12px;display:flex;flex-direction:column;gap:12px}.paint-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:10px 12px;background:#fbf8f1;border:1px solid #e7e2d9;border-radius:8px}.paint-toolgroup{display:flex;gap:6px}.paint-toolbar button{font-size:13px;padding:6px 12px}.paint-toolbar button.active{background:#1d1d1d;color:#fff;border-color:#1d1d1d}.paint-color,.paint-size{display:flex;align-items:center;gap:8px;font-size:13px;color:#555}.paint-color input[type=color]{width:32px;height:32px;padding:0;border:1px solid #d2cfca;border-radius:6px;background:none;cursor:pointer}.paint-size input[type=range]{width:120px}.paint-canvas-wrap{border:1px solid #e7e2d9;border-radius:8px;padding:8px;overflow:auto;max-height:70vh;text-align:center}.paint-canvas-wrap.transparent-bg{background-image:linear-gradient(45deg,#ddd 25%,transparent 25%),linear-gradient(-45deg,#ddd 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#ddd 75%),linear-gradient(-45deg,transparent 75%,#ddd 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0}.paint-canvas-wrap canvas{display:inline-block;max-width:100%;height:auto;cursor:crosshair;touch-action:none}.paint-actions{display:flex;justify-content:flex-end;gap:8px}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{background:#fff;border:1px solid #e7e2d9;border-radius:12px;padding:28px;width:100%;max-width:360px}.auth-card h1{margin:0 0 4px;font-size:24px}.auth-card p{margin:0 0 16px;color:#666;font-size:14px}.auth-card button{width:100%;background:#1d1d1d;color:#fff;border-color:#1d1d1d}:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:#faf7f2;color:#1d1d1d}
