:root{--bg: #0e121b;--panel: #0b0f17;--card: #121826;--line: #1c2636;--text: #e7eefc;--muted: #6b7b96;--accent: #00a8cc;--accent-yellow: #f0c040;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font:15px/1.4 -apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}.ws{display:flex;height:100%;position:relative}.ws-drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#0a0f1ae0;font-size:22px;font-weight:800;pointer-events:none}.ws-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px}.ws-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.ws-loading-spinner{width:36px;height:36px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.ws-loading p{color:var(--muted);font-size:14px;margin:0}.sidebar{width:200px;flex-shrink:0;display:flex;flex-direction:column;background:var(--panel);border-right:1px solid var(--line);overflow:hidden}.sb-header{display:flex;align-items:center;gap:8px;padding:10px;border-bottom:1px solid var(--line);flex-shrink:0}.sb-upload{flex:1;background:var(--accent);color:#fff;border:0;border-radius:7px;padding:7px 10px;font-size:12px;font-weight:700;cursor:pointer;text-align:center}.sb-upload input[type=file]{display:none}.sb-upload-busy{opacity:.5;pointer-events:none}.sb-count{font-size:12px;font-weight:700;color:var(--muted);white-space:nowrap}.sb-progress{height:3px;background:var(--line);flex-shrink:0}.sb-progress-fill{height:100%;background:var(--accent-yellow);transition:width .3s ease}.sb-error{font-size:11px;color:#f87171;padding:4px 10px;margin:0;border-bottom:1px solid #7f1d1d44}.sb-list{flex:1;overflow-y:auto;scrollbar-width:thin}.sb-row{display:flex;align-items:center;gap:7px;width:100%;padding:6px 8px;background:none;border:0;border-bottom:1px solid var(--line);cursor:pointer;text-align:left;transition:background .1s}.sb-row:hover{background:#12182688}.sb-row-active{background:#12182699;border-left:3px solid var(--accent)}.sb-row-labeled{opacity:.45;cursor:default}.sb-row-skipped{opacity:.35}.sb-row-error{opacity:.4}.sb-thumb{width:36px;height:27px;object-fit:cover;border-radius:4px;background:#1a1f2e;flex-shrink:0;display:block}.sb-label{flex:1;font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-status{font-size:12px;font-weight:900;flex-shrink:0;color:#2ec27e}.sb-row-skipped .sb-status{color:var(--muted)}.sb-row-error .sb-status{color:#f87171}.sb-done{padding:16px 10px;font-size:13px;font-weight:700;color:#2ec27e;text-align:center}.sb-empty{padding:24px 10px;font-size:13px;color:var(--muted);text-align:center}.ws-main{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}.top{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--panel);border-bottom:1px solid var(--line);flex-shrink:0}.top-spacer{flex:1}.sail-toggle{display:flex;background:var(--card);border-radius:8px;overflow:hidden;border:1px solid var(--line)}.sail-toggle button{background:none;border:0;color:var(--muted);padding:6px 12px;font-weight:800;font-size:12px;cursor:pointer;letter-spacing:.5px}.sail-toggle button.on{background:var(--accent);color:#fff}.top-btn{border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;padding:7px 14px;border:1px solid transparent;white-space:nowrap;transition:opacity .15s,background .15s}.top-btn:disabled{opacity:.35;cursor:default}.top-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);padding:8px 20px;font-size:14px}.top-btn-primary:not(:disabled):hover{background:#0090b0}.top-btn-secondary{background:transparent;color:var(--text);border-color:var(--line)}.top-btn-secondary:not(:disabled):hover{background:var(--card)}.top-btn-ghost{background:none;border-color:transparent;color:#f87171}.top-btn-ghost:not(:disabled):hover{color:#fca5a5}.top-btn-tertiary{background:none;border-color:transparent;color:var(--muted);font-size:12px;padding:7px 8px}.top-btn-tertiary:hover{color:var(--text)}.line-selector{display:flex;align-items:center;gap:8px;padding:8px 14px;overflow-x:auto;background:var(--panel);border-bottom:1px solid var(--line);flex-shrink:0;scrollbar-width:none}.line-selector::-webkit-scrollbar{display:none}.stripe-count-group{display:flex;align-items:center;gap:6px;flex-shrink:0}.stripe-count-label{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.4px}.stripe-count-tabs{display:flex;background:var(--card);border:1px solid var(--line);border-radius:6px;overflow:hidden}.stripe-count-tab{background:none;border:0;color:var(--muted);padding:4px 10px;font-size:13px;font-weight:700;cursor:pointer}.stripe-count-tab.on{background:var(--accent);color:#fff}.stripe-count-tab:disabled{opacity:.35;cursor:not-allowed}.stripe-divider{width:1px;height:24px;background:var(--line);flex-shrink:0}.chip-row{display:flex;gap:6px;flex-shrink:0}.stripe-chip{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:20px;border:2px solid transparent;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;background:transparent;color:var(--text);transition:opacity .15s,box-shadow .15s}.stripe-chip:hover{opacity:.9}.stripe-chip-active{box-shadow:0 0 0 3px color-mix(in srgb,var(--chip-color, var(--accent)) 40%,transparent)}.stripe-chip-done{opacity:.55}.stripe-chip-done:hover{opacity:.75}.chip-swatch{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chip-label{flex:1}.chip-dots-stepper{display:flex;align-items:center;gap:2px;background:#00000040;border-radius:10px;padding:1px 4px}.dots-btn{background:none;border:0;color:inherit;font-size:14px;cursor:pointer;padding:0 4px;line-height:1;opacity:.8}.dots-btn:disabled{opacity:.3;cursor:default}.dots-btn:not(:disabled):hover{opacity:1}.dots-count{font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;min-width:26px;text-align:center;opacity:.9}.chip-status{font-size:11px;font-weight:700;opacity:.65;font-variant-numeric:tabular-nums}.confirm-stripe-btn{background:var(--card);border:1px solid var(--line);border-radius:16px;color:var(--text);font-size:12px;font-weight:700;cursor:pointer;padding:5px 12px;flex-shrink:0;white-space:nowrap;transition:background .15s}.confirm-stripe-btn:hover{background:#1e2d44;border-color:var(--accent);color:var(--accent)}.canvas-area{flex:1;position:relative;display:flex;flex-direction:column;min-height:0}.canvas-wrap{flex:1;position:relative;overflow:hidden;background:#060a12;touch-action:none;-webkit-user-select:none;user-select:none}.canvas-wrap canvas{position:absolute;top:0;left:0;width:100%;height:100%}.photo-error-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#060a12e0}.photo-error-overlay p{color:var(--muted);font-size:15px;margin:0}.dot-delete-btn{position:absolute;z-index:10;transform:translate(-50%,-150%);background:#c0392b;color:#fff;border:0;width:28px;height:28px;border-radius:50%;font-size:13px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0008}.canvas-undo-btn{position:absolute;top:8px;left:8px;z-index:5;background:#1a2336cc;color:var(--text);border:1px solid var(--line);border-radius:8px;padding:5px 10px;font-size:13px;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;gap:5px}.canvas-undo-btn:hover{background:#253047cc}.canvas-undo-btn kbd{font-size:11px;background:var(--line);border-radius:4px;padding:1px 5px;font-family:inherit;color:var(--muted)}.metrics-bar{display:flex;gap:8px;padding:8px 14px;overflow-x:auto;background:var(--panel);border-top:1px solid var(--line);flex-shrink:0;scrollbar-width:none}.metrics-bar::-webkit-scrollbar{display:none}.metric-card{flex-shrink:0;min-width:80px;background:var(--card);border-left:3px solid var(--accent);border-radius:8px;padding:8px 10px}.metric-label{font-size:10px;font-weight:800;letter-spacing:.5px;margin-bottom:3px}.metric-values{display:flex;flex-direction:column}.metric-big{font-size:18px;font-weight:800;font-variant-numeric:tabular-nums}.metric-sub{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}.metric-empty{font-size:12px;color:var(--muted)}.hint{text-align:center;color:var(--muted);font-size:12px;margin:6px 14px 10px}.meta-bar{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--panel);border-bottom:1px solid var(--line);flex-wrap:wrap;flex-shrink:0}.meta-group{display:flex;align-items:center;gap:6px}.meta-label{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.4px}.meta-toggle{display:flex;background:var(--card);border-radius:6px;overflow:hidden}.meta-toggle button{background:none;border:0;color:var(--muted);padding:5px 10px;font-weight:700;font-size:12px;cursor:pointer;letter-spacing:.3px}.meta-toggle button.on{background:#1c3050;color:#7eb8f7}.meta-notes{flex:1;min-width:160px;background:var(--card);border:1px solid var(--line);border-radius:6px;color:var(--text);font-size:13px;padding:5px 10px;outline:none}.meta-notes::placeholder{color:var(--muted)}.meta-notes:focus{border-color:var(--accent)}.save-spinner{display:inline-block;width:12px;height:12px;margin-right:6px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}.upload-error{display:flex;align-items:center;gap:12px;background:#2d0f0f;color:#f87171;border-bottom:1px solid #7f1d1d;padding:8px 14px;font-size:13px;font-weight:600;flex-shrink:0}.upload-error button{margin-left:auto;background:#7f1d1d;color:#fca5a5;border:0;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer}.draft-pill{font-size:12px;font-weight:700;color:#f59e0b;background:#f59e0b22;border:1px solid #f59e0b44;border-radius:12px;padding:3px 10px}.ws-drag:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;border:3px dashed var(--accent);pointer-events:none;z-index:100}.ob-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#060a12d9;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ob-modal{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:28px 32px;max-width:480px;width:90%;box-shadow:0 24px 48px #000a}.ob-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.ob-logo{font-size:28px}.ob-title{font-size:20px;font-weight:800;margin:0;color:var(--text)}.ob-steps{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:12px}.ob-steps li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--text);line-height:1.5}.ob-step-num{flex-shrink:0;width:24px;height:24px;background:var(--accent);color:#fff;border-radius:50%;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-top:1px}.ob-steps li strong{color:var(--text)}.ob-steps li kbd{display:inline-block;background:var(--line);border-radius:4px;padding:1px 5px;font-size:11px;font-family:inherit;color:var(--muted)}.ob-shortcuts{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px 16px;margin-bottom:20px}.ob-shortcuts-title{font-size:11px;font-weight:800;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;display:block;margin-bottom:10px}.ob-shortcut-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 14px;align-items:center;font-size:13px}.ob-shortcut-grid kbd{background:var(--line);border-radius:5px;padding:2px 7px;font-size:12px;font-family:inherit;color:var(--text);font-weight:700;justify-self:start}.ob-shortcut-grid span{color:var(--muted)}.ob-cta{width:100%;background:var(--accent);color:#fff;border:0;border-radius:10px;padding:12px;font-size:15px;font-weight:800;cursor:pointer;transition:background .15s}.ob-cta:hover{background:#0090b0}.sidebar-wrap{display:flex;flex-direction:column;flex-shrink:0}.sidebar-wrap .sidebar{flex:1}.gallery-btn{background:var(--card);border:0;border-top:1px solid var(--line);color:var(--muted);font-size:13px;font-weight:600;padding:10px 16px;text-align:left;cursor:pointer;transition:background .15s,color .15s;width:200px}.gallery-btn:hover{background:var(--line);color:var(--text)}.gallery-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000a;display:flex;align-items:stretch;justify-content:flex-end}.gallery-panel{width:min(900px,100%);background:var(--bg);border-left:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}.gallery-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);flex-shrink:0}.gallery-header h2{margin:0;font-size:16px;font-weight:700}.gallery-count{background:var(--accent);color:#fff;border-radius:10px;padding:1px 8px;font-size:12px;margin-left:8px}.gallery-close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;line-height:1;padding:4px}.gallery-close:hover{color:var(--text)}.gallery-status{padding:40px;text-align:center;color:var(--muted);font-size:14px}.gallery-error{color:#f66}.gallery-grid{flex:1;overflow-y:auto;padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.gallery-card{background:var(--card);border:1px solid var(--line);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .1s}.gallery-card:hover{border-color:var(--accent);transform:scale(1.02)}.gallery-thumb{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:var(--panel)}.gallery-card-meta{display:flex;gap:6px;align-items:center;padding:6px 8px;font-size:11px}.gallery-sail-type{background:var(--accent);color:#fff;border-radius:4px;padding:1px 5px;font-weight:700}.gallery-stripe-count{color:var(--muted)}.gallery-date{color:var(--muted);margin-left:auto}.gallery-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#000c;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.gallery-lightbox-img{max-width:90vw;max-height:90vh;border-radius:6px;box-shadow:0 8px 40px #0008}.gp{min-height:100vh;background:var(--bg);color:var(--text);display:flex;flex-direction:column}.gp-header{display:flex;align-items:center;gap:16px;padding:14px 24px;border-bottom:1px solid var(--line);background:var(--panel);flex-shrink:0}.gp-back{color:var(--accent);text-decoration:none;font-size:13px;font-weight:600;white-space:nowrap}.gp-back:hover{text-decoration:underline}.gp-title{margin:0;font-size:17px;font-weight:700;flex:1}.gp-count{background:var(--accent);color:#fff;border-radius:12px;padding:2px 10px;font-size:12px;font-weight:700}.gp-spinner-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.gp-spinner{width:44px;height:44px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.gp-spinner-label{color:var(--muted);font-size:14px;margin:0}.gp-error{flex:1;display:flex;align-items:center;justify-content:center;color:#f66;font-size:14px}.gp-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px}.gp-grid{padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.gp-card{background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden;cursor:pointer;text-align:left;transition:border-color .15s,transform .12s,box-shadow .12s;padding:0}.gp-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px #0006}.gp-thumb{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:var(--panel)}.gp-card-meta{display:flex;align-items:center;gap:6px;padding:8px 10px;font-size:11px}.gp-sail-badge{background:var(--accent);color:#fff;border-radius:4px;padding:1px 6px;font-weight:800;font-size:10px}.gp-stripes{color:var(--muted)}.gp-date{color:var(--muted);margin-left:auto}.gp-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#000d;display:flex;align-items:center;justify-content:center;animation:fade-in .15s ease}.gp-lightbox-img{max-width:92vw;max-height:90vh;border-radius:8px;box-shadow:0 12px 48px #0009}.gp-lightbox-close{position:fixed;top:18px;right:20px;background:#0008;border:1px solid #fff3;color:#fff;border-radius:50%;width:36px;height:36px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.gp-lightbox-close:hover{background:#fff2}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.save-flash{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:#1a3a2a;border:1px solid #2d6b46;color:#5dcc8a;border-radius:10px;padding:12px 24px;font-size:15px;font-weight:700;white-space:nowrap;z-index:400;pointer-events:none;animation:flash-in-out 2.2s ease forwards}@keyframes flash-in-out{0%{opacity:0;transform:translate(-50%) translateY(12px)}12%{opacity:1;transform:translate(-50%) translateY(0)}75%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-6px)}}.sb-upload-progress{padding:6px 12px 4px;border-bottom:1px solid var(--line)}.sb-upload-progress-bar{height:4px;background:var(--line);border-radius:2px;overflow:hidden}.sb-upload-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .15s ease}.sb-upload-progress-label{display:block;font-size:11px;color:var(--muted);margin-top:4px}.gp-lightbox-prev,.gp-lightbox-next{position:fixed;top:50%;transform:translateY(-50%);background:#0008;border:1px solid #fff2;color:#fff;border-radius:50%;width:48px;height:48px;font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:301}.gp-lightbox-prev{left:16px}.gp-lightbox-next{right:16px}.gp-lightbox-prev:hover,.gp-lightbox-next:hover{background:#fff2}.gp-lightbox-meta{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:#000a;border:1px solid #fff1;border-radius:8px;padding:8px 16px;font-size:13px;z-index:301}.gp-lightbox-counter{color:var(--muted);margin-left:6px}.gp-lightbox-delete{background:none;border:none;cursor:pointer;font-size:16px;padding:2px 4px;border-radius:4px;opacity:.7;transition:opacity .15s,background .15s;margin-left:8px}.gp-lightbox-delete:hover{opacity:1;background:#e74c3c33}.sb-row-main{flex:1;min-width:0;display:flex;align-items:center;background:none;border:none;cursor:pointer;padding:0 8px;height:100%;text-align:left;color:inherit}.sb-row-delete{flex-shrink:0;background:none;border:none;cursor:pointer;font-size:13px;padding:4px 8px;opacity:0;transition:opacity .15s;color:inherit}.sb-row:hover .sb-row-delete{opacity:.5}.sb-row:hover .sb-row-delete:hover{opacity:1}.gp-geo{color:#adf;font-size:12px}.gp-ip{color:var(--muted);font-size:11px;font-family:monospace}
