:root{color:#172026;background:radial-gradient(circle at 18% 0%,rgb(197 232 222 / 70%),transparent 30%),linear-gradient(135deg,#f6f3eb,#eef5f2 48%,#f7f7fa);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,textarea{font:inherit}button,a{-webkit-tap-highlight-color:transparent}.shell{width:min(1180px,calc(100% - 32px));margin:0 auto}.page{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:22px;padding:28px 0;align-items:start}.app-frame{min-height:100vh}.panel{background:#ffffffd6;border:1px solid rgb(23 32 38 / 10%);border-radius:16px;box-shadow:0 24px 70px #1720261a;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.upload-panel{padding:30px}.result-panel{position:sticky;top:24px;padding:24px;text-align:center}.page-title{margin-bottom:26px}.page-title p:last-child{max-width:580px;margin:10px 0 0;color:#66736d;line-height:1.6}.eyebrow{margin:0 0 8px;color:#587166;font-size:12px;font-weight:800;letter-spacing:0}h1,h2{margin:0;line-height:1.12;letter-spacing:0}h1{font-size:38px}h2{font-size:22px}.form{display:grid;gap:20px}.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px}.section-head div{display:grid;gap:4px}.section-head strong{font-size:17px}.section-head span,.file-picker strong{color:#66736d;font-size:13px;font-weight:600}.text-block-list{display:grid;gap:14px}.text-block-editor{display:grid;gap:10px;padding:14px;border:1px solid #d8e0dc;border-radius:14px;background:#fff}.text-block-editor>span,.text-block-editor-header span{color:#334139;font-size:13px;font-weight:800}.text-block-editor-header{display:flex;align-items:center;justify-content:space-between}textarea,input{width:100%;border:1px solid #d8e0dc;border-radius:12px;color:#172026;background:#fbfcfb;outline:none}textarea{min-height:190px;resize:vertical;padding:14px;line-height:1.68}input{height:46px;padding:0 14px}textarea:focus,input:focus{border-color:#2f8f73;box-shadow:0 0 0 4px #2f8f7321}.file-picker{display:grid;gap:6px;place-items:center;padding:24px;border:1px dashed #8ea59b;border-radius:16px;background:linear-gradient(180deg,#f9fbf9,#eef6f1);cursor:pointer;transition:border-color .16s ease,background .16s ease,transform .16s ease}.file-picker input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.file-picker span{color:#236d59;font-weight:900}.file-picker.drag-active{border-color:#236d59;background:linear-gradient(180deg,#effaf5,#dcf1e8);transform:translateY(-1px)}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.preview-grid.empty{display:block;padding:18px;color:#66736d;text-align:center;border:1px solid #dfe6e2;border-radius:14px;background:#fff}.preview-item{position:relative;overflow:hidden;border:1px solid #dfe6e2;border-radius:14px;background:#fff;cursor:grab;transition:border-color .16s ease,box-shadow .16s ease,opacity .16s ease,transform .16s ease}.preview-item.dragging{opacity:.55;cursor:grabbing}.preview-item.drag-over{border-color:#236d59;box-shadow:0 0 0 4px #236d591f;transform:translateY(-2px)}.preview-item img{display:block;width:100%;aspect-ratio:1;object-fit:cover}.preview-item span{display:block;padding:8px;color:#66736d;font-size:12px}.preview-remove{position:absolute;top:8px;right:8px;z-index:2;display:inline-grid;width:30px;height:30px;place-items:center;border:1px solid rgb(255 255 255 / 70%);border-radius:999px;color:#fff;background:#172026b8;cursor:pointer;font-size:20px;line-height:1}.primary-button,.secondary-button,.danger-button,.image-actions a,.icon-button,.copy-pill,.ghost-button{display:inline-flex;min-height:46px;align-items:center;justify-content:center;border:1px solid transparent;border-radius:12px;padding:0 18px;font-weight:850;text-decoration:none;cursor:pointer}.primary-button{color:#fff;background:linear-gradient(135deg,#1f7a63,#2d9b78);box-shadow:0 12px 26px #1f7a6338}.primary-button:disabled{cursor:wait;opacity:.72}.secondary-button,.image-actions a{color:#172026;background:#edf3ef;border-color:#d8e0dc}.danger-button{color:#fff;background:#b8322a}.icon-button{min-width:48px;width:48px;padding:0;color:#fff;background:#172026;font-size:26px;line-height:1}.ghost-button{min-height:32px;padding:0 10px;color:#66736d;background:#f2f5f3;border-color:#dfe6e2;font-size:12px}.wide-button{width:100%}.message{min-height:22px;margin:0;color:#66736d}.hidden{display:none}.qr{display:block;width:220px;height:220px;margin:20px auto;border:1px solid #dfe6e2;border-radius:14px;background:#fff}.link-box{display:grid;gap:10px}.timer-line{color:#66736d}.mobile-shell{width:min(720px,100%);margin:0 auto;background:#f6f3eb;min-height:100vh}.mobile-content{padding:16px}.mobile-header{display:flex;gap:14px;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding:18px;border:1px solid rgb(23 32 38 / 10%);border-radius:18px;background:#fff;box-shadow:0 16px 42px #17202614}.mobile-header h1{font-size:26px}.countdown{flex:0 0 auto;min-width:78px;padding:9px 10px;border-radius:999px;color:#236d59;background:#e8f4ef;text-align:center}.mobile-text-blocks{display:grid;gap:12px}.copy-card{display:grid;gap:12px;padding:14px;border:1px solid #d8e0dc;border-radius:18px;background:#fff;box-shadow:0 10px 30px #17202612}.copy-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.copy-card-top span{color:#587166;font-size:13px;font-weight:900}.copy-pill{min-height:40px;padding:0 18px;color:#fff;background:#172026;border-radius:999px}.body-text{white-space:pre-wrap;overflow-wrap:anywhere;margin:0;padding:14px;border:1px solid #e2e8e4;border-radius:14px;background:#fbfcfb;line-height:1.75;font-family:inherit}.save-tip{margin:16px 0;padding:12px;border:1px solid #d8e0dc;border-radius:14px;color:#66736d;background:#fff}.image-list{display:grid;gap:18px;margin-bottom:18px}.image-item{display:grid;gap:10px}.image-item img{display:block;width:100%;height:auto;border:1px solid #d8e0dc;border-radius:18px;background:#fff}.image-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.sticky-actions{position:sticky;bottom:0;display:grid;gap:10px;margin:0 -16px -16px;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:#f6f3ebf0;border-top:1px solid #d8e0dc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.download-queue{display:grid;gap:8px;padding:10px;border:1px solid #d8e0dc;border-radius:16px;background:#fff}.download-queue span{color:#587166;font-size:13px;font-weight:850;text-align:center}.loading,.expired{padding:40px 0;text-align:center}.expired{display:grid;gap:14px}.expired p{margin:0;color:#66736d}@media(max-width:860px){.page{grid-template-columns:1fr;padding:16px 0}.result-panel{position:static}.upload-panel{padding:18px}h1{font-size:30px}}
