:root{--canvas:#f7f8fa;--canvas-soft:#eff1f5;--surface:#fff;--surface-2:#f0f2f5;--surface-3:#e9edf2;--divider:#e2e6ec;--divider-strong:#d6dbe3;--text:#0e1014;--text-2:#555a63;--text-3:#868d97;--accent:#2d7a4a;--accent-soft:#e7efe9;--danger:#b54330;--danger-soft:#f1e1dd;--radius-card:28px;--radius-panel:22px;--radius-chip:14px;--radius-pill:9999px;--shadow-card:0 1px 1px #0f0f0f05, 0 10px 36px #0f0f0f0f;--shadow-soft:0 6px 24px #0f0f0f0a;--shadow-lift:0 1px 1px #0f0f0f08, 0 18px 56px #0f0f0f14;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, Arial, "Segoe UI", Roboto, sans-serif;--font-mono:ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;--ease-spring:cubic-bezier(.2, 1.08, .4, 1);--ease-ios:cubic-bezier(.32, .72, 0, 1);--ease-out:cubic-bezier(.22, .61, .36, 1)}*{box-sizing:border-box;corner-shape:superellipse(1)}html,body{background:var(--canvas);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;text-wrap:pretty;margin:0;padding:0;font-size:15px;line-height:1.5}h1,h2,h3,h4,.card__title,.card__sub,.field__hint,.local-note,.events__title,.thumbcluster__title,.field__label,.btn-row__caption{text-wrap:balance}body{min-height:100vh}button,input,textarea{color:inherit;font-family:inherit}button{cursor:pointer;background:0 0;border:none;padding:0}button:disabled{cursor:not-allowed}a{color:inherit;text-decoration:none}::selection{background:var(--accent-soft);color:var(--text)}.btn:focus-visible,.input:focus-visible,.dropzone:focus-visible,.filerow__remove:focus-visible,.input-wrap__toggle:focus-visible{box-shadow:0 0 0 1px var(--surface), 0 0 0 2.5px var(--text);outline:none}.dropzone:focus-visible{box-shadow:0 0 0 2px var(--canvas), 0 0 0 4px var(--text)}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.shell{flex-direction:column;align-items:center;min-height:100vh;padding:56px 32px 96px;display:flex}.shell__head{justify-content:space-between;align-items:center;width:100%;max-width:640px;margin-bottom:56px;display:flex}.shell__mark{letter-spacing:-.005em;color:var(--text);align-items:center;gap:6px;font-size:16px;font-weight:500;display:inline-flex}.shell__logo{filter:drop-shadow(0 2px 4px #0f0f0f1a)drop-shadow(0 6px 14px #0f0f0f24);flex:none;width:24px;height:24px;display:block}.shell__head-right{align-items:center;gap:10px;min-width:0;display:inline-flex}.shell__divider{background:var(--divider-strong);opacity:.7;flex:none;width:1px;height:14px;display:inline-block}@media (max-width:520px){.shell__divider{display:none}}.shell__credit{letter-spacing:.01em;color:var(--text-4,var(--text-3));opacity:.88;white-space:nowrap;font-size:11px;font-weight:400;text-decoration:none;transition:opacity .14s,color .14s}a.shell__credit:hover{opacity:1;color:var(--text-2);text-underline-offset:3px;text-decoration:underline;text-decoration-thickness:1px}a.shell__credit:focus-visible{box-shadow:0 0 0 2px var(--canvas), 0 0 0 4px var(--text);border-radius:4px;outline:none}@media (max-width:520px){.shell__credit{display:none}}.shell__source{color:var(--text-3);border-radius:var(--radius-pill);align-items:center;gap:8px;height:28px;padding:0 10px 0 8px;font-size:13px;font-weight:500;transition:color .12s,background .12s;display:inline-flex}.shell__source:hover{color:var(--text);background:var(--surface-2)}.shell__source:focus-visible{box-shadow:0 0 0 2px var(--canvas), 0 0 0 4px var(--text);outline:none}.shell__source svg{flex-shrink:0;display:block}.shell__tail{align-items:center;gap:12px;display:flex}.shell__main{flex-direction:column;gap:24px;width:100%;max-width:640px;display:flex}.shell__foot{width:100%;max-width:640px;color:var(--text-3);justify-content:space-between;align-items:center;gap:16px;margin-top:24px;font-size:12px;display:flex}.shell__foot-left,.shell__foot-right{align-items:center;gap:10px;min-width:0;display:flex}.shell__foot-left{flex:1;min-width:0}.shell__foot-right{flex-shrink:0}.credchip{background:var(--surface-2);border-radius:var(--radius-pill);height:26px;color:var(--text-2);white-space:nowrap;align-items:center;gap:8px;max-width:60%;padding:0 12px 0 10px;font-size:12px;font-weight:500;display:inline-flex;overflow:hidden}.credchip__dot{border-radius:var(--radius-pill);background:var(--accent);flex-shrink:0;width:6px;height:6px}.credchip__label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.card{background:var(--surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);animation:card-enter .36s var(--ease-spring) both;padding:44px}.card--lift{box-shadow:var(--shadow-lift)}.upload__head{justify-content:space-between;align-items:baseline;gap:16px;margin:0 0 8px;display:flex}@keyframes card-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card__title{letter-spacing:-.01em;margin:0 0 12px;font-size:28px;font-weight:600;line-height:1.2}.card__sub{color:var(--text-2);max-width:44ch;margin:0 0 32px;font-size:14px;line-height:1.55}.card__section{margin-top:28px}.card__section:first-of-type{margin-top:0}.card__title+.card__section{margin-top:32px}.field{flex-direction:column;gap:10px;display:flex}.field__label{color:var(--text-2);font-size:13px;font-weight:500}.field__hint{color:var(--text-3);margin-top:2px;font-size:12px}.input{background:var(--surface-2);border-radius:var(--radius-pill);width:100%;color:var(--text);border:none;outline:none;padding:14px 20px;font-size:14px;transition:background .12s}.input::placeholder{color:var(--text-3)}.input:focus{background:var(--surface-3)}.input--mono{font-family:var(--font-mono);letter-spacing:-.01em;font-size:13px}.input-wrap{position:relative}.input-wrap .input{padding-right:52px}.input-wrap__toggle{border-radius:var(--radius-pill);width:32px;height:32px;color:var(--text-3);background:0 0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.input-wrap__toggle:hover:not(:disabled){background:var(--surface-3);color:var(--text-2)}.btn{border-radius:var(--radius-pill);height:44px;transition:background .12s ease, color .12s ease, opacity .12s ease, transform .24s var(--ease-spring);white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:0 22px;font-size:14px;font-weight:500;display:inline-flex}.btn:active:not(:disabled){transition:transform 60ms ease-out;transform:scale(.97)}.filerow__remove:active:not(:disabled),.input-wrap__toggle:active:not(:disabled){transition:transform 60ms ease-out;transform:scale(.94)}.filerow__remove,.input-wrap__toggle{transition:background .12s ease, color .12s ease, transform .24s var(--ease-spring)}.btn--sm{height:32px;padding:0 14px;font-size:13px}.btn--primary{background:var(--text);color:#fafafa}.btn--primary:hover:not(:disabled){background:#1a1a1a}.btn--primary:disabled{opacity:.35}.btn--ghost{color:var(--text-2);background:0 0}.btn--ghost:hover:not(:disabled){color:var(--text);background:var(--surface-2)}.btn--quiet{background:var(--surface-2);color:var(--text)}.btn--quiet:hover:not(:disabled){background:var(--surface-3)}.btn--copy{will-change:transform}.btn-copy__stack{grid-template-areas:"label";place-items:center;line-height:1;display:inline-grid}.btn-copy__label{opacity:0;filter:blur(4px);pointer-events:none;transition:opacity .18s var(--ease-out), transform .22s var(--ease-out), filter .18s var(--ease-out);will-change:transform, opacity, filter;grid-area:label;transform:translateY(-6px)}.btn-copy__label[data-active=true]{opacity:1;filter:blur();transition:opacity .22s var(--ease-out) .12s, transform .26s var(--ease-spring) .12s, filter .22s var(--ease-out) .12s;transform:translateY(0)}.btn--copy[data-state=idle] .btn-copy__label[data-active=true]{transition-delay:0s}@media (prefers-reduced-motion:reduce){.btn-copy__label,.btn-copy__label[data-active=true]{filter:none;transition:opacity .16s linear;transform:none}}.btn-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.btn-row__caption{font-size:13px}.kbd{background:var(--surface-2);height:26px;font-family:var(--font-mono);color:var(--text-3);letter-spacing:0;-webkit-user-select:none;user-select:none;border-radius:9px;align-items:center;padding:0 9px;font-size:11px;display:inline-flex}.dropzone{background:var(--surface-2);border-radius:var(--radius-panel);text-align:center;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:16px;width:100%;min-height:220px;padding:40px;transition:background .14s;display:flex;position:relative}.dropzone:hover,.dropzone--active{background:var(--surface-3)}.dropzone__glyph{transition:transform .36s var(--ease-spring);will-change:transform}.dropzone--active .dropzone__glyph{transform:scale(1.08)rotate(45deg)}@media (prefers-reduced-motion:reduce){.dropzone__glyph{transition:none}.dropzone--active .dropzone__glyph{transform:none}}.dropzone__primary{color:var(--text);font-size:15px;font-weight:500}.dropzone__secondary{color:var(--text-3);font-size:13px}.dropzone__glyph{border-radius:var(--radius-pill);background:var(--surface);width:48px;height:48px;box-shadow:var(--shadow-soft);color:var(--text-2);justify-content:center;align-items:center;display:flex}.dropzone__input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.filepanel{background:var(--surface);border-radius:var(--radius-panel);animation:filepanel-enter .36s var(--ease-spring) both;flex-direction:column;margin:0;padding:0;transition:background .16s,box-shadow .16s;display:flex;position:relative}.filepanel:before{content:"";background:var(--surface-2);border-radius:var(--radius-panel);opacity:0;pointer-events:none;z-index:0;transition:opacity .16s;position:absolute;inset:-10px -16px}.filepanel>*{z-index:1;position:relative}.filepanel--active:before{opacity:1}@keyframes filepanel-enter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.filepanel__head{justify-content:space-between;align-items:center;gap:16px;padding:4px 0 12px;display:flex}.filepanel__head .muted{font-size:12px}.filepanel__actions{align-items:center;gap:4px;display:flex}.filelist{margin-top:0;flex-direction:column;margin-block:0;padding-left:0;list-style:none;display:flex}.filelist--scroll{max-height:320px;padding-right:6px;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000 0,#000 14px calc(100% - 14px),#0000 100%);mask-image:linear-gradient(#0000 0,#000 14px calc(100% - 14px),#0000 100%)}.filelist--scroll::-webkit-scrollbar{width:6px}.filelist--scroll::-webkit-scrollbar-thumb{background:var(--divider-strong);border-radius:var(--radius-pill)}.filelist--scroll::-webkit-scrollbar-track{background:0 0}.filerow{grid-template-columns:1fr auto auto;align-items:center;gap:16px;padding:12px 0;display:grid}.filerow--compact{grid-template-columns:1fr auto}.filelist--upload{margin-top:24px}.filerow--withthumb{grid-template-columns:40px 1fr auto auto}.filerow__thumb{object-fit:cover;background:var(--surface-3);border-radius:10px;width:40px;height:40px;display:block}.filerow+.filerow{border-top:1px solid var(--divider)}.filerow__text{flex-direction:column;min-width:0;display:flex}.filerow__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.filerow__meta{color:var(--text-3);margin-top:2px;font-size:12px}.filerow__status{color:var(--text-3);font-size:12px}.filerow__status--done{color:var(--accent)}.filerow__status--err{color:var(--danger)}.filerow__remove{border-radius:var(--radius-pill);width:28px;height:28px;color:var(--text-3);background:0 0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex}.filerow__remove:hover{background:var(--surface-2);color:var(--text)}.progress{background:var(--surface-3);border-radius:var(--radius-pill);width:100%;height:6px;overflow:hidden}.progress__fill{background:var(--accent);border-radius:var(--radius-pill);height:100%;transition:width .36s cubic-bezier(.22,.61,.36,1);position:relative;overflow:hidden}.progress__fill:after{content:"";will-change:transform;pointer-events:none;background:linear-gradient(100deg,#0000 0%,#ffffff38 50%,#0000 100%);animation:2.6s linear infinite progress-shimmer;position:absolute;inset:0;transform:translate(-100%)}.progress__fill--complete:after,.progress__fill--idle:after{display:none}.progress__fill--complete{transition:width .6s cubic-bezier(.22,.61,.36,1)}.progress__fill--idle{background:var(--text)}@keyframes progress-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (prefers-reduced-motion:reduce){.progress__fill:after{animation:none;display:none}}.metric{align-items:baseline;gap:0;display:flex}.bigvalue{letter-spacing:-.03em;color:var(--text);font-variant-numeric:tabular-nums;font-size:56px;font-weight:600;line-height:1}.bigvalue__unit{color:var(--text-3);letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-left:2px;font-size:28px;font-weight:500}.card__sub--after-row{margin-top:18px}.card__sub--tight{margin:0 0 20px}.stats{flex-direction:column;margin-top:32px;display:flex}.stat{grid-template-columns:1fr auto;align-items:baseline;gap:16px;padding:14px 0;display:grid}.stat+.stat{border-top:1px solid var(--divider)}.stat__label{color:var(--text-2);font-size:14px}.stat__value{color:var(--text);font-variant-numeric:tabular-nums;font-size:14px;font-weight:500}.stat__value--muted{color:var(--text-3);font-weight:400}.statuspill{border-radius:var(--radius-pill);background:var(--surface-2);height:28px;color:var(--text);letter-spacing:0;align-items:center;gap:8px;padding:0 14px;font-size:12px;font-weight:500;display:inline-flex}.statuspill__dot{border-radius:var(--radius-pill);background:var(--text-3);width:6px;height:6px}.statuspill--live .statuspill__dot{background:var(--accent);animation:1.8s ease-in-out infinite pulse}.statuspill--done .statuspill__dot{background:var(--accent);animation:.6s dot-pulse-once}@keyframes dot-pulse-once{0%{transform:scale(1)}40%{transform:scale(1.6)}to{transform:scale(1)}}.statuspill--err{background:var(--danger-soft);color:var(--danger)}.statuspill--err .statuspill__dot{background:var(--danger)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.events{flex-direction:column;gap:0;margin-top:32px;display:flex}.events__title{color:var(--text-3);margin:0 0 14px;font-size:13px;font-weight:500}.event{grid-template-columns:64px 1fr;align-items:baseline;gap:16px;padding:8px 0;display:grid}.event__time{color:var(--text-3);font-variant-numeric:tabular-nums;font-size:11px}.event__msg{color:var(--text-2);font-size:13px;line-height:1.5}.thumbcluster{margin-top:32px}.thumbcluster__title{color:var(--text-3);margin:0 0 16px;font-size:13px;font-weight:500}.thumbcluster__grid{flex-wrap:wrap;gap:12px;padding:6px 4px;display:flex}.thumbcluster__item{background:var(--surface-3);width:56px;height:56px;transform:rotate(var(--tilt,0deg));animation:thumb-enter .58s var(--ease-spring) both;will-change:transform, opacity;border-radius:12px;overflow:hidden;box-shadow:0 1px 2px #0f0f0f0a,0 6px 18px #0f0f0f14}.thumbcluster__item img{object-fit:cover;width:100%;height:100%;display:block}@keyframes thumb-enter{0%{opacity:0;transform:rotate(0)scale(.6)}60%{opacity:1}to{opacity:1;transform:rotate(var(--tilt,0deg)) scale(1)}}@media (prefers-reduced-motion:reduce){.thumbcluster__item{animation:none}}.skill{background:var(--surface-2);border-radius:var(--radius-panel);max-height:56vh;margin-top:24px;padding:28px 32px;overflow:auto}.skill__pre{font-family:var(--font-mono);color:var(--text);white-space:pre-wrap;word-break:break-word;margin:0;font-size:12.5px;line-height:1.7}.past{margin-top:24px}.past__head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px;display:flex}.past__title{color:var(--text-3);margin:0;font-size:13px;font-weight:500}.past__list{flex-direction:column;gap:8px;display:flex}.past__item{background:var(--surface);border-radius:var(--radius-chip);grid-template-columns:1fr auto;align-items:center;gap:16px;padding:14px 16px;display:grid;box-shadow:0 1px 2px #0f0f0f0a}.past__meta{min-width:0}.past__name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:14px;font-weight:500;overflow:hidden}.past__date{color:var(--text-3);margin:3px 0 0;font-size:12px}.local-note{max-width:42ch;color:var(--text-2);margin:18px 0 0;font-size:13px}.local-note a{color:var(--text);text-decoration:underline;-webkit-text-decoration-color:var(--divider-strong);text-decoration-color:var(--divider-strong);text-underline-offset:3px;transition:text-decoration-color .12s}.local-note a:hover{-webkit-text-decoration-color:var(--text);text-decoration-color:var(--text)}.local-note a:focus-visible{box-shadow:0 0 0 2px var(--surface), 0 0 0 4px var(--text);border-radius:6px;outline:none}.notice{background:var(--danger-soft);color:var(--danger);border-radius:var(--radius-chip);margin-top:20px;padding:14px 20px;font-size:13px;line-height:1.5}.notice--quiet{background:var(--surface-2);color:var(--text-2)}.notice__actions{flex-wrap:wrap;align-items:center;gap:12px;margin-top:10px;display:flex}.spinner{border-radius:var(--radius-pill);border:1.5px solid var(--divider-strong);border-top-color:var(--text);width:14px;height:14px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.row{justify-content:space-between;align-items:center;gap:16px;display:flex}.row--baseline{align-items:baseline}.muted{color:var(--text-3)}.mono{font-family:var(--font-mono);letter-spacing:-.01em;font-size:12px}
