*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#f5f4f0;color:#1a1a1a}.app-header{background:#2c1a0e;color:#f5e6c8;padding:.65rem 1.25rem;display:flex;align-items:center;gap:1.25rem;box-shadow:0 2px 4px #0000004d;flex-wrap:wrap}.app-header .logo{font-size:1.2rem;font-weight:700;text-decoration:none;color:#f5e6c8;white-space:nowrap}.app-header nav{display:flex;gap:1rem}.app-header nav a{color:#d4b896;text-decoration:none;font-size:.95rem}.app-header nav a:hover{color:#fff}.app-header .header-user{margin-left:auto;display:flex;align-items:center;gap:.75rem;font-size:.83rem;color:#d4b896}.app-main{max-width:1100px;margin:0 auto;padding:1.25rem 1.5rem}.card{background:#fff;border-radius:8px;padding:1.25rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem}.btn{display:inline-block;padding:.45rem 1rem;border-radius:5px;border:none;cursor:pointer;font-size:.9rem;text-decoration:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn-primary{background:#2c6e49;color:#fff}.btn-primary:hover{background:#1e4d33}.btn-secondary{background:#e8e0d4;color:#333}.btn-secondary:hover{background:#d4c8b8}.btn-danger{background:#c0392b;color:#fff}.btn-danger:hover{background:#a93226}.btn-sm{padding:.35rem .75rem;font-size:.82rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.87rem;margin-bottom:.3rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.55rem .75rem;border:1px solid #ccc;border-radius:5px;font-size:1rem}.form-group input:focus{outline:2px solid #2c6e49;border-color:#2c6e49}.badge{display:inline-block;padding:.2rem .55rem;border-radius:12px;font-size:.75rem;font-weight:600}.badge-pending{background:khaki;color:#7a6a00}.badge-running{background:#b3d9ff;color:#003a6b}.badge-completed{background:#b3f0c8;color:#1a5c36}.badge-failed{background:#fbc4c4;color:#8b0000}.page-viewer-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.5rem;gap:.5rem}.back-link{color:#888;font-size:.85rem;text-decoration:none;display:block}.page-viewer-title{font-size:1.2rem;margin-top:.15rem}.mobile-tabs{display:none;border-bottom:2px solid #e0d8cc;margin-bottom:.5rem}.mobile-tab{flex:1;padding:.65rem .5rem;background:none;border:none;cursor:pointer;font-size:.9rem;color:#888;border-bottom:3px solid transparent;margin-bottom:-2px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;position:relative}.mobile-tab.active{color:#2c1a0e;border-bottom-color:#2c6e49;font-weight:600}.tab-badge{margin-left:.35rem;background:#2c6e49;color:#fff;font-size:.65rem;padding:1px 5px;border-radius:8px}.viewer-layout{display:grid;grid-template-columns:1fr 360px;gap:1rem;align-items:start}.viewer-container{position:relative;background:#333;border-radius:6px;min-height:600px;height:calc(100vh - 180px)}.lines-panel{background:#fff;border-radius:8px;padding:.85rem;overflow-y:auto;max-height:calc(100vh - 180px)}.lines-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #eee}.line-item{border:2px solid transparent;border-radius:5px;padding:.5rem .6rem;margin-bottom:.4rem;cursor:pointer;transition:border-color .12s,background .12s;-webkit-tap-highlight-color:transparent}.line-item:hover{border-color:#bbb}.line-item.active{border-color:#2c6e49;background:#f0f9f0}.line-item-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:.2rem}.line-num{font-size:.7rem;color:#bbb;font-variant-numeric:tabular-nums}.line-text{font-size:.88rem;color:#333}.line-corrected{font-size:.88rem;color:#2c6e49;font-style:italic}.line-corrected-badge{font-size:.7rem;color:#2c6e49;font-weight:700}.line-conf{font-size:.72rem;color:#999}.search-result{border-left:3px solid #2c6e49;padding:.75rem 1rem;margin-bottom:.75rem;background:#fff;border-radius:0 6px 6px 0;box-shadow:0 1px 2px #00000012}.search-result .result-text{font-size:.95rem;margin-bottom:.3rem}.search-result .result-meta{font-size:.8rem;color:#666}.empty-state{text-align:center;color:#888;padding:3rem}.error{color:#c0392b;padding:.75rem;background:#fbc4c4;border-radius:5px}.loading{color:#666;font-style:italic}.flex{display:flex}.gap-1{gap:.5rem}.gap-2{gap:1rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.items-center{align-items:center}.justify-between{justify-content:space-between}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding:.75rem;font-size:.88rem;color:#555;flex-wrap:wrap}.progress-bar{width:100%;height:8px;background:#e0d8cc;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#2c6e49;border-radius:4px;transition:width .2s ease}.page-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-top:1rem}.page-thumb-wrap{position:relative}.page-thumb{border:2px solid #e0d8cc;border-radius:6px;overflow:hidden;background:#fff;text-align:center;cursor:pointer;transition:border-color .15s;text-decoration:none;color:inherit;display:block}.page-thumb:hover{border-color:#2c6e49}.page-thumb img{width:100%;height:160px;object-fit:cover}.thumb-label{padding:.4rem;font-size:.82rem;color:#555}.page-delete-btn{position:absolute;top:5px;right:5px;width:24px;height:24px;border-radius:50%;border:none;background:#c0392bd9;color:#fff;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.page-thumb-wrap:hover .page-delete-btn{opacity:1}.page-delete-btn:hover{background:#a93226}.page-delete-btn:disabled{opacity:.4;cursor:default}@media(max-width:768px){.app-header{padding:.5rem 1rem;gap:.75rem}.app-header .logo{font-size:1.05rem}.app-header nav a{font-size:.88rem}.app-header .header-user{font-size:.78rem}.app-main{padding:.75rem .9rem}.mobile-tabs{display:flex}.viewer-layout{grid-template-columns:1fr;gap:0}.viewer-container{min-height:55vw;height:58vw;max-height:70vh;border-radius:0}.lines-panel{max-height:none;border-radius:0;padding:.75rem;border-top:1px solid #e0d8cc}.mobile-hidden{display:none!important}.line-item{padding:.6rem;margin-bottom:.5rem}.line-text,.line-corrected{font-size:.92rem}.page-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem}.page-thumb img{height:130px}.page-delete-btn{opacity:.85;width:28px;height:28px;font-size:.75rem}.pagination{gap:.5rem;font-size:.82rem}.pagination .btn{padding:.4rem .6rem;font-size:.8rem}.page-viewer-header{align-items:center}.page-viewer-title{font-size:1rem}.back-link{font-size:.78rem}input,select,textarea{font-size:16px!important}}@media(max-width:400px){.app-header nav{gap:.6rem}.app-header .header-user .btn{display:none}}
