:root{--ink:#13211e;--muted:#63726d;--panel:#f4f1ea;--paper:#fffdf7;--line:#d9d1c0;--green:#106b4f;--green-2:#cce9de;--blue:#214c72;--amber:#c06f18;--red:#ad3429;--shadow:0 24px 80px #19221f24}*{box-sizing:border-box}html,body{min-height:100%}body{color:var(--ink);background-color:#e8e1d3;background-image:linear-gradient(90deg,#13211e0f 1px,#0000 1px),linear-gradient(0deg,#13211e0d 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:34px 34px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;margin:0;font-family:Aptos,IBM Plex Sans,Segoe UI,sans-serif}button,input{font:inherit}button{cursor:pointer}.shell{grid-template-columns:320px minmax(0,1fr);min-height:100vh;display:grid}.side{color:#f8f3e7;background:#17231f;border-right:1px solid #ffffff1f;flex-direction:column;gap:18px;min-height:100vh;padding:28px;display:flex}.brand{align-items:center;gap:14px;margin-bottom:18px;display:flex}.brandMark{color:#17231f;background:#f3c45e;border:1px solid #ffffff52;border-radius:8px;place-items:center;width:52px;height:52px;font-family:Georgia,serif;font-weight:800;display:grid}.brand p,.brand h1{margin:0}.brand p{color:#b9c9c0;font-size:13px}.brand h1{font-family:Georgia,serif;font-size:30px;line-height:1}.statusBlock{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;grid-template-columns:44px 1fr;gap:12px;padding:14px;display:grid}.statusIcon{color:#f3c45e;background:#f3c45e1f;border-radius:8px;place-items:center;width:42px;height:42px;display:grid}.statusIcon.ok{color:#91e0bc;background:#91e0bc1f}.statusBlock span,.resultPanel span,.step span,.recentTop span,.eyebrow{color:inherit;letter-spacing:0;text-transform:uppercase;opacity:.68;font-size:12px;font-weight:800;display:block}.statusBlock strong{margin-top:2px;font-size:17px;display:block}.statusBlock small{color:#b9c9c0;margin-top:3px;display:block}.recent{flex-direction:column;gap:8px;margin-top:auto;display:flex}.recentTop{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.recentTop button{color:#f8f3e7;background:#ffffff0f;border:1px solid #ffffff24;border-radius:8px;place-items:center;width:32px;height:32px;display:grid}.recentItem{text-align:left;color:#f8f3e7;background:#ffffff0b;border:1px solid #ffffff1a;border-radius:8px;width:100%;min-height:54px;padding:10px;display:block}.recentItem span{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.recentItem small,.emptyRecent{color:#b9c9c0}.work{flex-direction:column;gap:20px;width:min(1120px,100%);margin:0 auto;padding:36px;display:flex}.topbar{justify-content:space-between;align-items:flex-start;gap:18px;display:flex}.topbar h2{letter-spacing:0;margin:4px 0 0;font-family:Georgia,serif;font-size:clamp(36px,6vw,72px);line-height:.98}.eyebrow{color:var(--green)}.pill{white-space:nowrap;border:1px solid var(--line);background:var(--paper);border-radius:8px;align-items:center;gap:8px;min-height:40px;padding:0 14px;font-weight:800;display:inline-flex;box-shadow:0 8px 24px #13211e14}.pill.review,.pill.failed{color:var(--red)}.dropZone{border:1px solid var(--line);background:var(--paper);box-shadow:var(--shadow);border-radius:8px;grid-template-columns:1fr auto;gap:12px;padding:14px;display:grid}.dropZone input{display:none}.fileButton,.launch{border:1px solid var(--line);border-radius:8px;justify-content:center;align-items:center;gap:10px;min-height:74px;font-weight:900;display:inline-flex}.fileButton{color:var(--ink);background:#fbf7ee;justify-content:flex-start;padding:0 20px;overflow:hidden}.fileButton span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.launch{color:#fffdf7;background:var(--green);border-color:#0d543e;min-width:238px;padding:0 24px;box-shadow:inset 0 -3px #0000002e}.launch:disabled{cursor:wait;opacity:.76}.timeline{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.step{border:1px solid var(--line);background:#fffdf7d1;border-radius:8px;min-height:142px;padding:16px}.stepDot{width:34px;height:34px;color:var(--muted);background:#e9e2d4;border-radius:8px;place-items:center;margin-bottom:16px;display:grid}.step.active .stepDot{background:var(--green-2);color:var(--green)}.step.done .stepDot{background:var(--green);color:#fff}.step.warn .stepDot,.step.failed .stepDot{color:var(--red);background:#f6dcc4}.step strong{min-height:44px;color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:8px;font-size:17px;line-height:1.28;display:-webkit-box;overflow:hidden}.resultPanel{border:1px solid var(--line);min-height:128px;box-shadow:var(--shadow);background:#fffdf7;border-radius:8px;grid-template-columns:68px 1fr;align-items:center;gap:18px;padding:22px;display:grid}.resultIcon{width:64px;height:64px;color:var(--green);background:var(--green-2);border-radius:8px;place-items:center;display:grid}.resultIcon.muted{color:var(--blue);background:#dbe9f4}.resultPanel strong{letter-spacing:0;margin-top:2px;font-family:Georgia,serif;font-size:clamp(24px,4vw,38px);display:block}.resultPanel p{color:var(--muted);margin:4px 0 0}.reviewList{gap:10px;display:grid}.reviewItem,.errorLine{color:var(--red);background:#fff2e8;border:1px solid #ad34293d;border-radius:8px;align-items:center;gap:10px;padding:14px 16px;display:flex}.reviewItem strong,.reviewItem span{display:block}.reviewItem span{color:#7f6457;margin-top:2px;font-size:13px}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:920px){.shell{grid-template-columns:1fr}.side{min-height:auto}.work{padding:24px}.dropZone,.timeline{grid-template-columns:1fr}.launch{width:100%}.topbar{flex-direction:column}}
