:root{color:#17201b;background:#f4f3ef;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}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;min-height:100dvh}button,input,select{font:inherit}.app-shell{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.toolbar{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid #d8d5cc;background:#fbfaf6;flex-shrink:0}.brand h1{margin:0;font-size:20px;line-height:1.1}.brand p{display:none;margin:4px 0 0;color:#59635d;font-size:13px}.upload-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.upload-button{min-height:38px;border:1px solid #1f2d25;border-radius:8px;padding:0 14px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;white-space:nowrap;font-size:14px;font-weight:600;color:#fff;background:#1f2d25}.upload-button.secondary-upload{color:#1f2d25;background:#fff}.upload-button input{display:none}.upload-button.disabled-hint{opacity:.45;cursor:not-allowed}.quick-actions{padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid #e2e0d8;background:#fbfaf6;flex-shrink:0;flex-wrap:wrap}.quick-actions-left{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.quick-actions-right{flex-shrink:0}.icon-btn{min-width:38px;min-height:38px;border:1px solid #c5c8c2;border-radius:8px;padding:0 8px;display:inline-flex;align-items:center;justify-content:center;gap:4px;background:#fff;color:#1f2d25;cursor:pointer;font-size:13px;transition:background .12s,border-color .12s}.icon-btn:hover{background:#f0efe8}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.icon-btn.active{background:#166b52;color:#fff;border-color:#166b52}.icon-btn-label{font-size:12px;font-weight:600}.rotation-label{min-width:32px;text-align:center;color:#59635d;font-size:13px;font-weight:600}.segmented{padding:3px;display:grid;grid-template-columns:1fr 1fr;gap:3px;border:1px solid #bfc2bb;border-radius:8px;background:#fff}.segmented button{min-height:32px;border:0;border-radius:6px;background:transparent;cursor:pointer;font-size:13px;font-weight:600;color:#59635d;padding:0 12px;white-space:nowrap}.segmented button.active{color:#fff;background:#166b52}.mode-segmented{min-width:120px}.primary,.secondary{min-height:40px;border-radius:8px;padding:0 18px;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;white-space:nowrap;font-size:14px;font-weight:700}.primary{color:#fff;background:#166b52;border:1px solid #166b52}.primary:disabled{opacity:.45;cursor:not-allowed}.secondary{background:#fff;color:#1f2d25;border:1px solid #c5c8c2}.export-btn-desktop{display:none}.advanced-panel{padding:14px 16px;border-bottom:1px solid #d8d5cc;background:#efede6;flex-shrink:0}.advanced-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:12px}.advanced-grid label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:#26342c}.advanced-grid label>span{display:flex;justify-content:space-between;align-items:center}.advanced-grid label em{font-style:normal;color:#59635d;font-weight:600;font-size:12px}.advanced-grid input[type=range]{width:100%;accent-color:#166b52}.advanced-grid select{width:100%;height:36px;border:1px solid #a9ada6;border-radius:6px;background:#fff;padding:0 10px;font-size:13px}.advanced-grid .checkbox-row{flex-direction:row;justify-content:space-between;align-items:center;min-height:36px}.checkbox-row input{width:18px;height:18px;accent-color:#166b52}.advanced-panel .secondary{width:100%}.preview-area{flex:1;min-height:0;padding:12px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.panel{min-width:0;min-height:0;display:flex;flex-direction:column;border:1px solid #d8d5cc;border-radius:10px;overflow:hidden;background:#fff;flex:1}.panel-title{min-height:40px;padding:0 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid #e2e0d8;flex-shrink:0}.panel-title strong{font-size:13px}.panel-title span{min-width:0;overflow:hidden;color:#66706a;font-size:11px;text-overflow:ellipsis;white-space:nowrap}.image-stage{position:relative;flex:1;min-height:200px;display:grid;place-items:center;overflow:auto;background:linear-gradient(45deg,#f2f2f0 25%,transparent 25%),linear-gradient(-45deg,#f2f2f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f2f2f0 75%),linear-gradient(-45deg,transparent 75%,#f2f2f0 75%);background-color:#fff;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.image-stage img,.image-stage canvas{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;box-shadow:0 8px 24px #25241e1f;background:#fff}.image-stage img{transition:transform .12s ease}.image-stage img.rotated-sideways{max-width:100%;max-height:100%}.image-stage span{color:#737a75;font-size:13px}.hidden{display:none}.processing{position:absolute;inset:0;display:grid;place-items:center;color:#fff;background:#17201b61;font-weight:700;font-size:14px}.export-bar-mobile{padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid #d8d5cc;background:#fbfaf6;flex-shrink:0}.export-bar-mobile .primary{flex-shrink:0}.export-summary{color:#59635d;font-size:12px;white-space:nowrap}.status-line{min-height:30px;padding:0 16px;display:flex;align-items:center;gap:8px;border-top:1px solid #d8d5cc;color:#4f5b54;background:#fbfaf6;font-size:12px;flex-shrink:0}.dot{width:7px;height:7px;border-radius:999px;background:#166b52;flex-shrink:0}.dot.busy{background:#bf7a13}@media(min-width:768px){.toolbar{padding:16px 24px}.brand h1{font-size:22px}.brand p{display:block}.upload-button{min-height:40px;padding:0 16px;font-size:14px}.quick-actions{padding:10px 24px}.icon-btn{min-height:36px}.export-btn-desktop{display:inline-flex}.advanced-panel{padding:16px 24px}.advanced-grid{grid-template-columns:repeat(2,1fr);gap:14px 20px}.preview-area{padding:16px 24px;flex-direction:row;gap:16px}.panel{flex:1}.image-stage{min-height:360px}.panel-title{min-height:44px;padding:0 14px}.panel-title strong{font-size:14px}.panel-title span{font-size:12px}.export-bar-mobile{display:none}.status-line{min-height:32px;padding:0 24px;font-size:13px}}@media(min-width:1024px){.advanced-grid{grid-template-columns:repeat(3,1fr)}.image-stage{min-height:420px}}.wechat-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000a6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:16px;animation:wechatFadeIn .2s ease-out}.wechat-modal-content{background:#fbfaf6;border:1px solid #d8d5cc;border-radius:14px;width:100%;max-width:440px;max-height:90vh;max-height:90dvh;display:flex;flex-direction:column;box-shadow:0 20px 40px #0000004d;animation:wechatSlideUp .25s cubic-bezier(.16,1,.3,1);overflow:hidden}.wechat-modal-header{padding:14px 16px;border-bottom:1px solid #e2e0d8;display:flex;align-items:center;justify-content:space-between}.wechat-modal-header h3{margin:0;font-size:16px;color:#17201b;font-weight:700}.wechat-modal-close{background:transparent;border:none;font-size:24px;line-height:1;color:#737a75;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s,color .15s}.wechat-modal-close:hover{background:#f0efe8;color:#17201b}.wechat-img-container{flex:1;min-height:0;padding:16px;display:grid;place-items:center;background:#efede6;overflow:auto}.wechat-preview-img{max-width:100%;max-height:48vh;max-height:48dvh;object-fit:contain;box-shadow:0 4px 16px #00000026;border-radius:4px;background:#fff;animation:wechatPulseOnce 1s ease-out;-webkit-touch-callout:default;pointer-events:auto}.wechat-loading{font-size:14px;color:#59635d}.wechat-modal-footer{padding:16px;border-top:1px solid #e2e0d8;background:#fbfaf6}.wechat-meta{display:flex;align-items:center;gap:8px;margin-bottom:12px}.wechat-size-tag{background:#e6f2ed;color:#166b52;font-size:11px;font-weight:700;padding:2px 6px;border-radius:4px}.wechat-size-val{font-size:12px;color:#59635d}.wechat-instruction{display:flex;align-items:center;gap:8px;color:#166b52;font-weight:700;font-size:13px;margin-bottom:10px}.wechat-hand-icon{animation:wechatFloatHand 1.6s infinite ease-in-out}.wechat-warning-tip{margin:0;font-size:11px;color:#8c765c;line-height:1.5;background:#fdfaf2;border:1px dashed #e6dbcc;padding:8px 10px;border-radius:6px}@keyframes wechatFadeIn{0%{opacity:0}to{opacity:1}}@keyframes wechatSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes wechatFloatHand{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes wechatPulseOnce{0%{transform:scale(.98)}50%{transform:scale(1.01)}to{transform:scale(1)}}
