:root{color-scheme:light;--page: #ffffff;--page-glow: #ffffff;--surface: #ffffff;--surface-soft: #f8fafc;--board: #e8e8ea;--line: #d9dee5;--line-strong: #c3ccd7;--text: #353b42;--muted: #6e7681;--blue: #3c7db6;--blue-dark: #2e6ea8;--blue-soft: #e6eff8;--ok: #57b25f;--warn: #f4c247;--bad: #da6464;--info: #4a9bdc;--aqua: #55c6cf;--violet: #bf61d9;--shadow: 0 16px 34px rgba(37, 57, 79, .08);--shadow-soft: 0 8px 18px rgba(37, 57, 79, .08);--radius-lg: 20px;--radius-md: 14px;--radius-sm: 10px}*{box-sizing:border-box}html{background:var(--page)}body{margin:0;min-height:100vh;color:var(--text);background:#fff;font-family:Frutiger,Avenir Next,Trebuchet MS,sans-serif}a{color:inherit}button,input,select{font:inherit}.shell{width:min(1740px,94vw);margin:0 auto;padding:1rem 0 2rem}.app{display:grid;gap:1.15rem}.page-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:0 .1rem}.section-kicker{margin:0 0 .25rem;color:var(--muted);font-size:.98rem}.page-head h1{margin:0;font-size:clamp(2.2rem,4vw,3.1rem);letter-spacing:-.04em}.page-head p{margin:.4rem 0 0;color:var(--muted);max-width:52rem;line-height:1.5}.glass{border:1px solid rgba(255,255,255,.72);background:linear-gradient(180deg,#f1f2f4,var(--board));box-shadow:var(--shadow);border-radius:var(--radius-lg)}.hero,.panel{padding:1.35rem 1.4rem 1.45rem}.config-panel{background:linear-gradient(180deg,#f1f4f7,#e8ecef)}.summary-panel,.workspace-panel,.debug-panel{background:linear-gradient(180deg,#efefef,#e7e7e8)}.panel-heading{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.panel-kicker{margin:0 0 .18rem;color:var(--blue);font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700}.panel-heading h2,.debug-head h2{margin:0;font-size:1.55rem;letter-spacing:-.02em}.panel-heading p,.debug-head p{margin:0;color:var(--muted);line-height:1.45}#configDetails summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;color:var(--text);font-weight:700}#configDetails summary::-webkit-details-marker{display:none}#configDetails summary:after{content:"▾";color:var(--blue);font-size:1.2rem;transition:transform .18s ease}#configDetails[open] summary:after{transform:rotate(180deg)}.summary-copy{display:grid;gap:.15rem}.summary-title{font-size:1.18rem}.summary-caption{color:var(--muted);font-weight:500;font-size:.92rem}.config-content{margin-top:1.1rem}.form-grid{display:grid;gap:.95rem;grid-template-columns:repeat(auto-fit,minmax(215px,1fr))}label{display:flex;flex-direction:column;gap:.45rem;font-size:.89rem;color:var(--text)}.field-caption{font-weight:700}.field-note{color:var(--muted);font-size:.8rem}input:not([type=checkbox]),select{width:100%;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:linear-gradient(180deg,#fff,#f7f9fb);color:var(--text);padding:.78rem .85rem;box-shadow:inset 0 1px #ffffffd9;transition:border-color .18s ease,box-shadow .18s ease}input:not([type=checkbox]):focus,select:focus{outline:none;border-color:#3c7db6a6;box-shadow:0 0 0 3px #3c7db624}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 1.1rem) calc(50% - .12rem),calc(100% - .8rem) calc(50% - .12rem);background-size:.34rem .34rem,.34rem .34rem;background-repeat:no-repeat}input[type=checkbox]{width:1.2rem;height:1.2rem;margin:.05rem 0 0;accent-color:var(--blue)}.checkbox-label{align-self:stretch;justify-content:flex-start}.hint{margin:.95rem 0 0;color:var(--muted);font-size:.88rem}code{background:#3c7db614;color:var(--blue-dark);padding:.15rem .35rem;border-radius:.35rem}.conn-row{margin-top:1rem;display:flex;align-items:center;justify-content:space-between;gap:.9rem;flex-wrap:wrap}.conn-status{display:flex;align-items:center;gap:.7rem;color:var(--muted);font-size:.92rem;background:#ffffffb8;border:1px solid var(--line);border-radius:999px;padding:.65rem .9rem}.conn-dot{width:.8rem;height:.8rem;border-radius:50%;border:1px solid rgba(0,0,0,.1);display:inline-block;box-shadow:0 0 0 3px #ffffffb8}.conn-idle{background:#96a1ad}.conn-checking{background:var(--warn)}.conn-ok{background:var(--ok)}.conn-fail{background:var(--bad)}.workspace-hint{margin-bottom:1rem;color:var(--muted)}.dropzone{border:2px dashed rgba(60,125,182,.34);border-radius:1.15rem;padding:1.9rem 1.4rem;text-align:center;display:grid;justify-items:center;gap:.6rem;background:linear-gradient(180deg,#fffffff2,#f1f6fbeb),radial-gradient(circle at top,rgba(60,125,182,.08),transparent 50%);transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease}.dropzone p,.dropzone span{margin:0}.dropzone.active{border-color:#3c7db6b8;transform:translateY(-1px);box-shadow:0 14px 28px #3c7db624}.button-like,button{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;background:linear-gradient(180deg,#fff,#f4f7fa);color:var(--text);border:1px solid var(--line-strong);border-radius:var(--radius-sm);padding:.74rem 1rem;cursor:pointer;font-weight:700;text-decoration:none;box-shadow:0 6px 14px #22395114;transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease,background .18s ease}.button-like:hover,button:hover:not(:disabled){border-color:#3c7db68c;transform:translateY(-1px);box-shadow:0 9px 18px #2239511f}.button-like{background:linear-gradient(180deg,#fbfdff,#edf3f8)}.btn-primary,#sendBtn{background:linear-gradient(180deg,#4886bc,var(--blue-dark));color:#fff;border-color:#2d5b8ab8;box-shadow:0 12px 22px #2e6ea838}.btn-primary:hover,#sendBtn:hover:not(:disabled){background:linear-gradient(180deg,#4d8ec6,#2a669c)}.btn-secondary{background:linear-gradient(180deg,#fff,#f2f5f8)}button:disabled{opacity:.56;cursor:not-allowed;transform:none;box-shadow:none}.actions{margin-top:1.05rem;display:flex;flex-wrap:wrap;gap:.7rem}.dropzone-queue{margin-top:1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:.95rem;max-height:56vh;overflow:auto}.global-progress{margin:1rem 0;padding:1rem 1.05rem;border:1px solid var(--line);border-radius:1rem;background:#ffffffbd}.global-progress-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.55rem;font-size:.97rem}#globalProgressPct{font-weight:700;font-size:1.45rem;color:var(--blue)}.global-progress-track{height:.8rem;background:#dce3ea;border-radius:999px;overflow:hidden;border:1px solid rgba(185,196,208,.75)}.global-progress-bar{height:100%;background:linear-gradient(90deg,#60a0d7,var(--blue));border-radius:999px;transition:width .3s ease;position:relative}.global-progress-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.42),transparent);animation:shimmer 1.8s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.global-progress-status{margin:.55rem 0 0;color:var(--muted);font-size:.88rem}.batch-panel{margin:1rem 0;padding:1rem 1.05rem;border:1px solid #dce2e8;border-radius:1rem;background:linear-gradient(180deg,#ffffffe0,#f4f7fae6);display:flex;justify-content:space-between;gap:1rem;align-items:center;flex-wrap:wrap}.batch-panel[hidden]{display:none}.batch-copy{display:grid;gap:.3rem}.batch-eyebrow{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);font-weight:700}.batch-title{margin:0;font-size:1.1rem}.batch-text{margin:0;color:var(--muted);font-size:.9rem}.batch-actions{display:flex;gap:.65rem;flex-wrap:wrap}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:.85rem}.stat-card{background:var(--surface);border:1px solid #e4eaf0;border-radius:1rem;padding:1rem 1.05rem;box-shadow:var(--shadow-soft)}.stat-card-head{display:flex;align-items:center;gap:.6rem;color:var(--muted);font-size:.76rem;text-transform:uppercase;letter-spacing:.11em;font-weight:700}.stat-dot{width:.7rem;height:.7rem;border-radius:50%;box-shadow:0 0 0 3px #0000000d}.stat-dot-blue{background:var(--blue)}.stat-dot-info{background:var(--info)}.stat-dot-ok{background:var(--ok)}.stat-dot-warn{background:var(--warn)}.stat-dot-bad{background:var(--bad)}.stat-dot-aqua{background:var(--aqua)}.stat-dot-violet{background:var(--violet)}.stat-value{margin-top:.95rem;font-size:1.8rem;font-weight:700;color:var(--text);line-height:1.18}.stat-value small{font-size:1rem;font-weight:500;color:var(--muted)}.stat-label{margin-top:.3rem;color:var(--muted);font-size:.9rem}.stat-warn .stat-value{color:var(--bad)}.queue{display:grid;gap:.95rem;max-height:58vh;overflow:auto}.queue-item{background:var(--surface);border:1px solid #e2e8ee;border-radius:1rem;overflow:hidden;box-shadow:var(--shadow-soft)}.queue-item-compact{background:#fff}.queue-preview-wrap{position:relative}.queue-preview{width:100%;height:168px;object-fit:cover;background:linear-gradient(180deg,#f3f6fa,#eaf0f6);cursor:zoom-in;display:block}.queue-preview-placeholder{display:grid;place-items:center;color:var(--muted);font-size:.78rem}.thumb-overlay{position:absolute;top:.7rem;left:.7rem;right:.7rem;display:flex;justify-content:space-between;align-items:center;pointer-events:none}.thumb-state{width:2rem;height:2rem;border-radius:50%;background:#fffffff2;border:1px solid rgba(0,0,0,.08);display:grid;place-items:center;font-size:.86rem;box-shadow:0 8px 16px #00000014}.thumb-state-pending{color:var(--blue)}.thumb-state-uploading{color:var(--warn)}.thumb-state-success{color:var(--ok)}.thumb-state-failed,.thumb-state-needs_file{color:var(--bad)}.thumb-actions{display:flex;gap:.4rem;pointer-events:auto}.icon-btn{width:2rem;height:2rem;border-radius:999px;padding:0;display:grid;place-items:center;line-height:1;background:#fffffff5}.retry-btn{color:#d08d00}.remove-btn{color:#c84f4f}.thumb-progress-wrap{position:absolute;left:.7rem;right:.7rem;bottom:.7rem;height:.55rem;background:#ffffffd1;border-radius:999px;overflow:hidden}.thumb-progress-bar{height:100%;background:linear-gradient(90deg,#60a0d7,var(--blue));transition:width .2s linear}.queue-card-body{padding:.95rem 1rem 1rem;display:grid;gap:.65rem}.queue-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.queue-file{margin:0;font-size:.98rem;font-weight:700;line-height:1.35;overflow-wrap:anywhere}.queue-badge{flex-shrink:0;border-radius:999px;padding:.33rem .58rem;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.queue-badge-pending{background:#3c7db61f;color:var(--blue-dark)}.queue-badge-uploading{background:#f4c2472e;color:#9e7200}.queue-badge-failed,.queue-badge-needs_file{background:#da646424;color:#ba4343}.queue-badge-success{background:#57b25f29;color:#2b8531}.queue-message{margin:0;min-height:2.6em;color:var(--muted);font-size:.86rem;line-height:1.5}.queue-foot{display:flex;justify-content:space-between;gap:1rem;color:var(--muted);font-size:.82rem}.queue-progress-value{color:var(--blue);font-weight:700}.status-pending{border-color:#3c7db63d}.status-uploading{border-color:#f4c2476b}.status-success{border-color:#57b25f6b}.status-failed,.status-needs_file{border-color:#da646461}.empty{color:var(--muted)}.debug-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.debug-output{margin:1rem 0 0;padding:1rem;border:1px solid #dbe2ea;border-radius:1rem;background:#ffffffd6;color:#4a5058;font-size:.8rem;line-height:1.45;max-height:280px;overflow:auto;white-space:pre-wrap;word-break:break-word}.toast{position:fixed;right:1rem;bottom:1rem;border:1px solid rgba(60,125,182,.24);background:#fffffff5;color:var(--text);border-radius:.85rem;padding:.75rem .95rem;box-shadow:0 14px 26px #25394f24}.preview-dialog{border:1px solid #d8dee5;border-radius:1rem;background:#fffffffa;padding:.9rem;max-width:min(92vw,900px);box-shadow:0 18px 42px #25394f33}.preview-dialog::backdrop{background:#3d48539e}.preview-dialog img{width:100%;max-height:76vh;object-fit:contain;border-radius:.8rem;border:1px solid #e0e6ec}.preview-close{margin-bottom:.75rem}.processing-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#f3f6f9e0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.processing-overlay[hidden]{display:none}.processing-spinner{width:3rem;height:3rem;border:4px solid rgba(60,125,182,.2);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.processing-overlay p{color:var(--muted);font-size:.95rem}.done-area{text-align:center;padding:2.2rem 1rem;background:#ffffffd1;border:1px solid #dde5ea;border-radius:1rem}.done-message{margin-bottom:1.25rem}.done-icon{display:inline-flex;width:3.6rem;height:3.6rem;border-radius:50%;background:#57b25f1f;border:2px solid rgba(87,178,95,.42);color:var(--ok);font-size:1.5rem;align-items:center;justify-content:center;margin-bottom:.8rem}.done-message h2{margin:0;color:#2d8233}.done-message p{margin:.5rem 0 0;color:var(--muted)}.done-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}.site-footer{display:flex;justify-content:space-between;gap:1rem;color:var(--muted);font-size:.95rem;padding:.4rem .1rem 0}.site-footer a{color:var(--blue);text-decoration:none}@media (max-width: 1080px){.page-head,.panel-heading,.debug-head,.site-footer{flex-direction:column;align-items:flex-start}}@media (max-width: 760px){.shell{width:min(96vw,100%);padding-top:1rem}.hero,.panel{padding:1rem}.actions{display:grid;grid-template-columns:1fr 1fr}.dropzone-queue,.stats{grid-template-columns:1fr}.batch-panel{padding:.9rem}.batch-actions{width:100%;display:grid;grid-template-columns:1fr}.queue-title-row{flex-direction:column}}@media (max-width: 560px){.actions{grid-template-columns:1fr}.conn-row,.page-head{width:100%}}
