:root{--paper: #f3f3ef;--surface: #ffffff;--surface-2: #faf9f6;--ink-900: #1b1e23;--ink-600: #4c525b;--ink-400: #888e98;--line: #e3e2db;--line-strong: #cdccc3;--accent: #3f6f4e;--accent-strong: #2f5b3d;--accent-ink: #ffffff;--accent-soft: #eaf1ec;--accent-line: #b6cdbd;--danger: #b3261e;--danger-soft: #fbeeed;--warning: #9a6a1a;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--radius-1: 6px;--radius-2: 9px;--radius-3: 13px;--font-title: "Spectral", Georgia, "Times New Roman", serif;--font-body: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "Cascadia Mono", Consolas, monospace}*{box-sizing:border-box}body{margin:0;font-family:var(--font-body);background:var(--paper);color:var(--ink-900);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}:focus-visible{outline:2px solid var(--accent-strong);outline-offset:2px;border-radius:3px}@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}.app{max-width:1400px;margin:0 auto;padding:var(--space-5) var(--space-4) var(--space-6)}.app-head{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;padding-bottom:var(--space-3);margin-bottom:var(--space-5);border-bottom:1px solid var(--line)}.app-head__brand{display:flex;align-items:baseline;gap:var(--space-3);min-width:0}.app-head h1{font-family:var(--font-title);font-weight:600;font-size:23px;color:var(--ink-900);margin:0;letter-spacing:.01em}.app-head__tag{font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-400);white-space:nowrap}.actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.actions .user{margin-left:var(--space-2);font-size:12px;color:var(--ink-400)}.actions .user a{color:var(--accent-strong);font-weight:500}button{font-family:var(--font-body);font-size:14px;font-weight:500;line-height:1.2;cursor:pointer;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-900);padding:8px 13px;border-radius:var(--radius-1);transition:border-color .15s ease,background-color .15s ease,color .15s ease}button:hover:not(:disabled){border-color:var(--ink-400);background:var(--surface-2)}button:disabled{opacity:.45;cursor:not-allowed}button.link{border:none;background:none;color:var(--accent-strong);padding:0;font-weight:500}button.link:hover:not(:disabled){background:none;text-decoration:underline}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-body);font-size:14px;font-weight:500;line-height:1.2;padding:9px 14px;border-radius:var(--radius-1);cursor:pointer;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-900);transition:border-color .15s ease,background-color .15s ease,color .15s ease}.btn:hover:not(:disabled){border-color:var(--ink-400);background:var(--surface-2)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--sm{padding:5px 10px;font-size:12.5px}.btn--primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:600}.btn--primary:hover:not(:disabled){background:var(--accent-strong);border-color:var(--accent-strong)}.btn--ghost{background:transparent;border-style:dashed;color:var(--ink-600)}.btn--ghost:hover:not(:disabled){color:var(--accent-strong);border-color:var(--accent-line);background:var(--accent-soft)}.btn--danger{color:var(--danger);border-color:var(--line-strong)}.btn--danger:hover:not(:disabled){background:var(--danger-soft);border-color:var(--danger)}.stepper{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-5)}.stepper__step{display:inline-flex;align-items:center;gap:var(--space-2);background:transparent;border:1px solid transparent;border-radius:999px;padding:6px 14px 6px 7px;color:var(--ink-400);cursor:pointer;font-family:var(--font-body)}.stepper__step:hover:not(.is-active){background:var(--surface-2);color:var(--ink-600);border-color:transparent}.stepper__step.is-active{background:var(--surface);border-color:var(--line);color:var(--ink-900);box-shadow:0 1px 2px #1b1e230d}.stepper__num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-family:var(--font-mono);font-size:12px;font-weight:600;background:var(--line);color:var(--ink-600)}.stepper__step.is-active .stepper__num{background:var(--accent);color:var(--accent-ink)}.stepper__label{font-size:14px;font-weight:500;white-space:nowrap}.stepper__count{font-family:var(--font-mono);font-size:11px;font-weight:600;background:var(--accent-soft);color:var(--accent-strong);border:1px solid var(--accent-line);border-radius:999px;padding:0 7px}.stepper__sep{flex:0 0 22px;height:1px;background:var(--line-strong)}.step-nav{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-4)}.step1{display:grid;grid-template-columns:minmax(340px,38%) 1fr;gap:var(--space-4);align-items:start}.step1__work{display:flex;flex-direction:column;gap:var(--space-4);min-width:0}.step1__work .step-nav{margin-top:0}.step1__preview{position:sticky;top:var(--space-4);align-self:start;height:calc(100vh - 2 * var(--space-4))}.step2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);align-items:start}.step2__nav{grid-column:1 / -1}.preview-pane{height:100%;display:flex;flex-direction:column;gap:var(--space-3);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-3);padding:var(--space-4);overflow:hidden}.preview-pane__head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-2)}.preview-pane__heading{min-width:0}.preview-pane__title{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.preview-pane__stamp{display:flex;flex-direction:column;gap:var(--space-1);font-size:12px;color:var(--ink-600)}.preview-pane__stamp select{font-family:var(--font-body);font-size:13px;color:var(--ink-900);padding:7px 9px;border:1px solid var(--line);border-radius:var(--radius-1);background:var(--surface)}.preview-pane__stamp select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.preview-pane__body{flex:1;min-height:0;border:1px solid var(--line);border-radius:var(--radius-2);background:var(--surface-2);overflow:hidden;display:flex}.preview-frame{width:100%;height:100%;border:none}.preview-img-wrap{width:100%;height:100%;overflow:auto;display:flex;justify-content:center}.preview-img{max-width:100%;height:auto;align-self:flex-start}.preview-loading{margin:auto;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--ink-400);font-size:13px}.spinner{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--line-strong);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.preview-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);text-align:center;padding:var(--space-6);background:var(--surface);border:1px dashed var(--line-strong);border-radius:var(--radius-3);color:var(--ink-600)}.preview-empty__eye{color:var(--accent)}.preview-empty__eye svg{width:38px;height:38px}.preview-empty p{margin:0;max-width:340px}@media (max-width: 1000px){.step1{grid-template-columns:1fr}.step1__preview{position:static;height:auto}.step1__preview:not(.is-open){display:none}.step1__preview.is-open{position:fixed;right:0;bottom:0;left:0;z-index:60;height:100vh;padding:0;top:0}.step1__preview.is-open .preview-pane{border:none;border-radius:0;height:100vh}}@media (max-width: 900px){.step2{grid-template-columns:1fr}}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-3);padding:var(--space-4)}.zone-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-4)}.zone-over{display:flex;align-items:center;gap:var(--space-2);margin:0;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-400)}.zone-step{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--ink-900);color:#fff;font-size:10px;line-height:1}.zone-title{font-family:var(--font-title);font-weight:600;font-size:20px;color:var(--ink-900);margin:var(--space-1) 0 0;display:flex;align-items:center;gap:var(--space-2)}.tabs{display:inline-flex;gap:2px;padding:3px;flex-wrap:wrap;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-2);margin-bottom:var(--space-3)}.tabs button{border:1px solid transparent;background:transparent;color:var(--ink-600);padding:6px 14px;border-radius:var(--radius-1);font-size:13px}.tabs button:hover:not(:disabled){background:var(--surface);color:var(--ink-900)}.tabs button.on{background:var(--surface);border-color:var(--accent-line);color:var(--accent-strong);font-weight:600;box-shadow:0 1px 2px #1b1e230f}.tabs button:disabled{opacity:.4}.upload{border:1px dashed var(--line-strong);border-radius:var(--radius-2);padding:var(--space-4);text-align:center;background:var(--surface-2)}.upload .muted{margin:var(--space-2) 0 0}.add-target{display:flex;flex-direction:column;gap:var(--space-1);margin:var(--space-3) 0;font-size:12.5px;color:var(--ink-600)}.add-target select{font-family:var(--font-body);font-size:13px;color:var(--ink-900);padding:6px 8px;border:1px solid var(--line);border-radius:var(--radius-1);background:var(--surface)}.breadcrumb{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-400);margin-bottom:var(--space-2);display:flex;flex-wrap:wrap;align-items:center;gap:2px}.breadcrumb button.link{font-family:var(--font-mono);color:var(--ink-600)}.breadcrumb button.link:hover{color:var(--accent-strong)}.item-list{list-style:none;padding:0;margin:0;max-height:420px;overflow:auto}.item-list li{display:flex;align-items:center;gap:var(--space-2);padding:7px 8px;border-bottom:1px solid var(--line);font-size:13.5px;color:var(--ink-900)}.item-list li:last-child{border-bottom:none}.item-list li.unsupported{opacity:.5}.item-list li.muted{color:var(--ink-400)}.file-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);width:100%}.folder{border:none;background:none;text-align:left;width:100%;padding:0;color:var(--ink-900);font-size:13.5px}.folder:hover{color:var(--accent-strong);background:none;border-color:transparent}.add{font-size:12px;padding:4px 10px;white-space:nowrap}.pc-count{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--accent-strong);background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:999px;padding:1px 9px;line-height:1.6}.pc-switch{display:inline-flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--ink-600);cursor:pointer;-webkit-user-select:none;user-select:none}.pc-switch input{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}.pc-empty{margin:0;padding:var(--space-5) var(--space-4);text-align:center;color:var(--ink-400);font-size:13.5px;border:1px dashed var(--line-strong);border-radius:var(--radius-2);background:var(--surface-2)}.pc-empty--nested{padding:var(--space-3);text-align:left;background:transparent;border:none}.pc-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.pc-list--nested{margin-top:var(--space-2)}.pc-piece{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-2);transition:border-color .15s ease,box-shadow .15s ease}.pc-piece:hover{border-color:var(--line-strong)}.pc-piece.is-dragging{border-color:var(--accent-line);border-style:dashed;background:var(--accent-soft);box-shadow:0 6px 18px #1b1e231f}.pc-piece.is-previewing{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.pc-piece__main{display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:var(--space-3)}.pc-piece__row2{display:flex;align-items:flex-end;gap:var(--space-3);flex-wrap:wrap;padding-left:calc(20px + 46px + 2 * var(--space-3))}.pc-piece__actions{display:flex;align-items:center;gap:var(--space-1)}.pc-grip{border:none;background:none;padding:2px;cursor:grab;line-height:1;color:var(--ink-400);font-size:16px;touch-action:none}.pc-grip:hover{color:var(--ink-600);background:none;border-color:transparent}.pc-grip:active{cursor:grabbing}.pc-no{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:46px;padding:3px 6px;border:1px solid var(--line-strong);border-radius:var(--radius-1);background:var(--surface-2);cursor:pointer;transition:border-color .15s ease,background-color .15s ease}.pc-no:hover{border-color:var(--accent-line);background:var(--accent-soft)}.pc-piece.is-previewing .pc-no{border-color:var(--accent)}.pc-no__label{font-family:var(--font-mono);font-size:8.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-400);line-height:1.4}.pc-no__num{font-family:var(--font-mono);font-size:16px;font-weight:600;color:var(--ink-900);line-height:1.1;font-variant-numeric:tabular-nums}.pc-field{width:100%;font-family:var(--font-body);font-size:14px;color:var(--ink-900);padding:7px 9px;border:1px solid var(--line);border-radius:var(--radius-1);background:var(--surface);transition:border-color .15s ease,box-shadow .15s ease}.pc-field::placeholder{color:var(--ink-400)}.pc-field:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.pc-title{font-size:15px;font-weight:500;padding:9px 11px;min-width:0}.pc-field--sm{font-size:12.5px;padding:6px 9px;width:160px}.pc-origin{margin-left:auto;align-self:center;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-400);border:1px solid var(--line);border-radius:999px;padding:1px 8px}.pc-select{display:flex;flex-direction:column;gap:2px}.pc-select__label{font-family:var(--font-mono);font-size:8.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-400)}.pc-select select{font-family:var(--font-body);font-size:12px;color:var(--ink-900);padding:5px 7px;border:1px solid var(--line);border-radius:var(--radius-1);background:var(--surface);cursor:pointer}.pc-select select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.pc-icon{border:1px solid var(--line);background:var(--surface);color:var(--ink-600);width:30px;height:30px;min-width:30px;border-radius:var(--radius-1);cursor:pointer;font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.pc-icon svg{display:block;width:18px;height:18px;flex:0 0 auto}.pc-icon:hover:not(:disabled){background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent-line)}.pc-icon.is-on{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent-line)}.pc-icon:disabled{opacity:.4;cursor:not-allowed}.pc-icon--danger{color:var(--ink-400)}.pc-icon--danger:hover:not(:disabled){background:var(--danger-soft);color:var(--danger);border-color:var(--danger)}.pc-fardes{display:flex;flex-direction:column;gap:var(--space-3)}.pc-farde{border:1px solid var(--line);border-radius:var(--radius-3);background:var(--surface-2);padding:var(--space-3);border-left:3px solid var(--line-strong)}.pc-farde.is-active{border-left-color:var(--accent)}.pc-farde__head{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.pc-fno{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:46px;padding:3px 6px;border-radius:var(--radius-1);background:var(--ink-900);color:#fff}.pc-fno__label{font-family:var(--font-mono);font-size:8.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;opacity:.7;line-height:1.4}.pc-fno__num{font-family:var(--font-mono);font-size:16px;font-weight:600;line-height:1.1}.pc-farde__title{flex:1;min-width:120px;font-family:var(--font-title);font-size:15px;font-weight:600}.pc-farde__tools{display:flex;align-items:center;gap:var(--space-1)}.pc-tag{font-family:var(--font-body);font-size:11.5px;font-weight:500;padding:5px 10px;border-radius:999px;cursor:pointer;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-600);white-space:nowrap}.pc-tag:hover{border-color:var(--accent-line);color:var(--accent-strong)}.pc-tag.is-on{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent-strong);font-weight:600}.pc-confirm{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;margin:var(--space-2) 0;padding:var(--space-2) var(--space-3);font-size:12.5px;color:var(--ink-600);background:var(--danger-soft);border:1px solid #f0c8c5;border-radius:var(--radius-2)}.pc-add-farde{align-self:flex-start}@media (max-width: 560px){.pc-piece__row2{padding-left:0}.pc-field--sm{width:100%}.pc-origin{margin-left:0}}.options{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.options label{display:flex;flex-direction:column;font-size:12.5px;gap:var(--space-1);color:var(--ink-600)}.options fieldset{border:1px solid var(--line);border-radius:var(--radius-2);padding:var(--space-3);margin:0;display:flex;flex-direction:column;gap:var(--space-2);background:var(--surface-2)}.options legend{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-400);padding:0 var(--space-1)}.options .row{display:flex;gap:var(--space-2)}.options .row label{flex:1}.options input,.options select,.settings-grid input,.settings-grid select,.logo-box input:not([type=color]):not([type=file]),.logo-box select,.save-dest input{font-family:var(--font-body);font-size:13.5px;color:var(--ink-900);padding:7px 9px;border:1px solid var(--line);border-radius:var(--radius-1);background:var(--surface);transition:border-color .15s ease,box-shadow .15s ease}.options input::placeholder,.settings-grid input::placeholder,.save-dest input::placeholder{color:var(--ink-400)}.options input:focus,.options select:focus,.settings-grid input:focus,.settings-grid select:focus,.logo-box input:focus,.logo-box select:focus,.save-dest input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.options input:disabled,.options select:disabled{background:var(--surface-2);color:var(--ink-400);cursor:not-allowed}.field-check{flex-direction:row!important;align-items:center;gap:var(--space-2)!important;font-size:13px;color:var(--ink-900);cursor:pointer}.field-check input[type=checkbox]{width:16px;height:16px;flex:none;cursor:pointer}input[type=checkbox],input[type=radio]{accent-color:var(--accent)}.color-row{display:flex;gap:var(--space-2);align-items:center}.color-row input[type=color]{width:40px;height:34px;padding:0;border:1px solid var(--line);border-radius:var(--radius-1);cursor:pointer;flex:none}.color-row input:not([type=color]){flex:1}.generate{width:100%;background:var(--accent);color:var(--accent-ink);border:1px solid var(--accent);padding:12px;font-size:15px;font-weight:600;border-radius:var(--radius-2);font-family:var(--font-body)}.generate:hover:not(:disabled){background:var(--accent-strong);border-color:var(--accent-strong)}.progress{margin-top:var(--space-3)}.progress-bar{height:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);transition:width .3s ease}.result{margin-top:var(--space-4);background:var(--surface-2);border:1px solid var(--line);border-left:3px solid var(--accent);padding:var(--space-3) var(--space-4);border-radius:var(--radius-2)}.result h3{margin:0 0 var(--space-2);font-family:var(--font-title);font-size:16px;color:var(--ink-900)}.result ul{margin:0;padding-left:var(--space-4);display:flex;flex-direction:column;gap:2px}.result a{color:var(--accent-strong);font-size:13.5px}.save-dest{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--line)}.save-dest h4{margin:0 0 var(--space-2);font-size:13px;font-weight:600;color:var(--ink-900)}.save-dest .row{display:flex;gap:var(--space-2)}.save-dest input{flex:1}.sp-folder{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);font-size:12.5px;color:var(--ink-600)}.folder-browser{border:1px solid var(--line);border-radius:var(--radius-2);padding:var(--space-2);margin:var(--space-2) 0;max-height:280px;overflow:auto;background:var(--surface-2)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b1e2373;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-6) var(--space-4);overflow:auto;z-index:50}.modal{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-3);padding:var(--space-5);width:100%;max-width:640px;box-shadow:0 18px 50px #1b1e2338}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.modal-head h2{margin:0;font-family:var(--font-title);font-weight:600;color:var(--ink-900);font-size:19px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin:var(--space-3) 0}.settings-grid label{display:flex;flex-direction:column;font-size:12.5px;gap:var(--space-1);color:var(--ink-600)}@media (max-width: 560px){.settings-grid{grid-template-columns:1fr}}.logo-box{border:1px solid var(--line);border-radius:var(--radius-2);padding:var(--space-3) var(--space-4) var(--space-4);margin-top:var(--space-3);background:var(--surface-2)}.logo-box>label{display:flex;flex-direction:column;font-size:12.5px;gap:var(--space-1);color:var(--ink-600);margin-top:var(--space-2)}.logo-box legend{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-400);padding:0 var(--space-1)}.logo-preview{max-width:260px;max-height:90px;display:block;margin-bottom:var(--space-2);border:1px solid var(--line);border-radius:var(--radius-1)}.modal-actions{display:flex;justify-content:flex-end;align-items:center;gap:var(--space-3);margin-top:var(--space-4)}.muted{color:var(--ink-400)}.small{font-size:12px}.error{color:var(--danger);font-weight:500}.warning{color:var(--warning)}
