:root{--green:#008c4a;--green-dark:#006b3f;--green-soft:#e2f4eb;--red:#d8171f;--red-soft:#fee7e7;--ink:#071528;--muted:#64748b;--line:#d8e0e8;--surface:#ffffff;--surface-soft:#f7fafc;--shadow:0 18px 48px rgba(15,23,42,0.08)}*{box-sizing:border-box}body{margin:0;background:#f6f8fb;color:var(--ink);font-family:Segoe UI,Arial,sans-serif;overflow:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.65}.icon{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.login-page{min-height:100vh;height:100vh;padding:0 56px 28px;flex-direction:column;background:#f7f9fb}.login-header,.login-page{display:flex;overflow:hidden}.login-header{position:relative;width:calc(100% + 112px);height:88px;margin-left:-56px;align-items:center;padding:0 46px;background:#fff}.login-header:before,.top-header:before{content:"";position:absolute;inset:0 auto 0 0;width:min(760px,44vw);background:linear-gradient(90deg,#00965b,#007a4a);-webkit-clip-path:polygon(0 0,82% 0,66% 100%,0 100%);clip-path:polygon(0 0,82% 0,66% 100%,0 100%);z-index:0}.login-card{width:min(1320px,calc(100vw - 112px));min-height:min(735px,calc(100vh - 130px));margin:34px auto 0;display:grid;grid-template-columns:1.2fr .95fr;overflow:hidden;border:1px solid var(--line);border-radius:12px;background:#fff;box-shadow:0 22px 58px rgba(15,23,42,.12)}.login-visual{position:relative;display:grid;place-items:center;padding:38px;background:radial-gradient(circle at 42% 45%,rgba(0,140,74,.11),transparent 0 40%),linear-gradient(180deg,#fff,#f8fbfa)}.login-asset{width:min(680px,100%);max-height:610px;display:block;object-fit:contain}.login-visual.has-asset .audit-illustration,.login-visual.has-asset .login-pill{display:none}.audit-illustration{position:relative;width:min(650px,100%);aspect-ratio:1.02}.audit-illustration:before{content:"";position:absolute;inset:6% 3% 12%;border-radius:46% 54% 44% 56%;background:#eaf7f1}.audit-illustration:after{content:"";position:absolute;left:16%;right:10%;top:30%;height:42%;border:3px dashed rgba(0,140,74,.25);border-radius:26px}.clipboard{z-index:2;left:31%;top:8%;width:39%;height:72%;padding:58px 32px 28px;border:10px solid #0b6c43;border-radius:14px;background:#fff;box-shadow:0 18px 38px rgba(15,23,42,.16)}.clip,.clipboard{position:absolute}.clip{top:-34px;left:28%;width:44%;height:44px;border-radius:8px;background:linear-gradient(#6f7778,#3d4647);box-shadow:0 6px 12px rgba(0,0,0,.18)}.clip:before{content:"";position:absolute;top:-14px;left:42%;width:22px;height:22px;border-radius:50%;background:#596365;box-shadow:inset 0 0 0 7px #e9eeee}.clipboard h2{margin:0 0 22px;font-size:25px}.audit-row{display:grid;grid-template-columns:34px 1fr;grid-gap:12px;gap:12px;margin-bottom:22px}.audit-row span{grid-row:span 2;display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:var(--green);color:#fff}.audit-row .icon{width:18px;height:18px}.audit-row b,.audit-row i{display:block;height:9px;border-radius:999px;background:#e5e9eb}.audit-row b{width:72%}.chart{display:flex;align-items:flex-end;gap:8px;width:86px;height:70px;margin-top:12px;padding:12px;border-radius:8px;background:#edf8f3}.chart span{width:14px;border-radius:2px 2px 0 0;background:linear-gradient(#39bd7b,#0a8b4c)}.chart span:first-child{height:22px}.chart span:nth-child(2){height:38px}.chart span:nth-child(3){height:52px}.validation-rate{position:absolute;left:30px;bottom:22px;width:70px;height:70px;display:grid;place-items:center;border:12px solid #35bb78;border-radius:50%;color:var(--green);font-size:20px;font-weight:900}.ai-chip,.camera-badge,.shield-badge{position:absolute;z-index:3;display:grid;place-items:center;color:var(--green);background:rgba(255,255,255,.88);border:3px solid rgba(0,140,74,.25);box-shadow:0 12px 28px rgba(0,140,74,.12)}.ai-chip{left:10%;top:30%;width:108px;height:108px;border-radius:22px;font-size:46px;font-weight:900}.shield-badge{right:7%;top:30%;width:112px;height:112px;border-radius:26px}.camera-badge .icon,.shield-badge .icon{width:68px;height:68px;stroke-width:1.9}.camera-badge{right:11%;top:52%;width:82px;height:82px;border-radius:20px}.camera-badge .icon{width:48px;height:48px}.delivery-truck{position:absolute;z-index:4;left:7%;bottom:11%;width:205px;height:88px;display:grid;place-items:center;border:3px solid #d9e0e2;border-radius:7px 28px 7px 7px;background:#fff;color:var(--green);font-size:30px;font-weight:900;box-shadow:0 12px 22px rgba(15,23,42,.12)}.delivery-truck:after,.delivery-truck:before{content:"";position:absolute;bottom:-18px;width:34px;height:34px;border-radius:50%;background:#1c252a;box-shadow:inset 0 0 0 9px #48515a}.delivery-truck:before{left:26px}.delivery-truck:after{right:28px}.delivery-box{position:absolute;z-index:4;right:5%;bottom:8%;width:190px;height:118px;display:grid;place-items:center;border-radius:5px;background:linear-gradient(90deg,transparent 43%,#10915a 43% 58%,transparent 58%),linear-gradient(#dca45d,#c98b42);color:var(--green);font-size:24px;font-weight:900;box-shadow:0 16px 28px rgba(110,72,22,.18)}.login-pill{position:absolute;left:50%;bottom:54px;transform:translateX(-50%);display:inline-flex;align-items:center;gap:12px;padding:14px 28px;border:1px solid rgba(0,140,74,.25);border-radius:999px;background:rgba(255,255,255,.9);color:var(--ink);font-size:18px;font-weight:900}.login-pill .icon{color:var(--green)}.login-form-panel{display:grid;align-items:center;padding:64px 72px;border-left:1px solid #edf1f5}.login-form{max-width:430px}.login-form h1{margin:0 0 14px;font-size:26px;line-height:1}.login-form p{margin:0 0 44px;color:#58677c;font-size:20px;line-height:1.5}.login-form label{display:block;margin-bottom:26px}.login-input{height:58px;display:flex;align-items:center;gap:14px;padding:0 16px;border:1px solid #cbd5df;border-radius:8px;background:#fff}.login-input .icon{flex:0 0 auto;color:#526273}.login-input input{flex:1 1;min-width:0;height:100%;border:0;outline:0;color:var(--ink);font-size:18px}.login-input button{display:grid;place-items:center;border:0;background:transparent;color:#526273}.login-error{display:block;margin:-10px 0 18px;color:var(--red)}.login-submit{width:100%;height:58px;display:inline-flex;align-items:center;justify-content:center;gap:12px;border:0;border-radius:8px;background:linear-gradient(180deg,#009b59,#007a45);color:#fff;font-size:18px;font-weight:900;box-shadow:0 12px 22px rgba(0,122,69,.18)}.login-help{display:flex;align-items:center;gap:18px;margin-top:24px;padding-top:24px;border-top:1px solid #dfe6ee}.login-help span{display:grid;place-items:center;width:52px;height:52px;border:2px solid var(--green);border-radius:999px;color:var(--green)}.login-help p{margin:0;font-size:17px;line-height:1.4}.home-page{height:100vh;padding:0 56px 12px;flex-direction:column}.home-page,.top-header{display:flex;overflow:hidden}.top-header{position:relative;width:calc(100% + 112px);height:72px;flex:0 0 auto;margin-left:-56px;align-items:center;justify-content:space-between;padding:0 46px;background:#fff}.brand-logo{width:150px;height:auto;display:block;object-fit:contain}.brand-logo,.user-menu{position:relative;z-index:1}.user-menu{display:inline-flex;align-items:center;gap:14px;min-height:44px;padding:6px 14px;border:0;border-radius:8px;background:rgba(0,38,28,.72);color:#fff;font-weight:800}.user-menu span:first-child{display:inline-grid;place-items:center;width:32px;height:32px;border:3px solid #fff;border-radius:999px}.chevron{font-size:24px;line-height:1}.filters-panel,.pagination,.stats-grid,.table-card{max-width:1420px;width:100%;margin-inline:auto}.filters-panel{display:grid;grid-template-columns:355px 320px 142px;align-items:flex-end;grid-gap:46px;gap:46px;margin-top:18px;padding:14px 34px 16px;border:1px solid var(--line);border-radius:10px;background:var(--surface);box-shadow:var(--shadow)}label>span{display:block;margin-bottom:8px;font-size:16px;font-weight:800}input,select,textarea{border:1px solid #cbd5df;background:#fff;color:var(--ink)}.filters-panel input{width:100%;height:46px;border-radius:9px;padding:0 16px;font-size:20px}.input-with-icon{position:relative}.input-with-icon .icon{position:absolute;right:16px;top:11px;color:#667789;pointer-events:none}.big-close,.search-btn,.view-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;background:linear-gradient(180deg,#009b59,#007a45);color:#fff;font-weight:800;box-shadow:0 10px 18px rgba(0,122,69,.18)}.search-btn{height:46px;border-radius:8px;font-size:17px}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:24px;gap:24px;margin-top:16px;flex:0 0 auto}.stat-card{position:relative;display:flex;align-items:center;gap:22px;min-height:92px;padding:16px 24px;border:1px solid var(--line);border-radius:10px;background:var(--surface);box-shadow:var(--shadow)}.stat-icon,.title-icon{display:inline-grid;place-items:center;border-radius:999px;color:var(--green);background:var(--green-soft)}.stat-icon{width:60px;height:60px}.stat-card.processed .stat-icon{background:linear-gradient(180deg,#009a57,#008246);color:#fff}.stat-card.bad .stat-icon{background:#ffdada;color:var(--red)}.stat-card p{margin:0 0 8px;color:#334155;font-size:18px}.stat-card strong{color:var(--green);font-size:34px;line-height:1}.stat-card.bad strong{color:var(--red)}.check-filter{position:absolute;right:32px;top:36px}.check-filter input{position:absolute;opacity:0}.check-filter span{display:block;width:24px;height:24px;border:2px solid var(--green);border-radius:5px}.check-filter input:checked+span{background:var(--green);box-shadow:inset 0 0 0 4px #fff}.table-card{flex:1 1 auto;min-height:0;margin-top:18px;overflow:auto;border:1px solid var(--line);border-radius:10px;background:var(--surface);box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse}td,th{border-right:1px solid #e0e7ee;border-bottom:1px solid #e0e7ee;padding:9px 16px;text-align:center;font-size:18px}th{position:-webkit-sticky;position:sticky;top:0;z-index:1;height:52px;background:#f8fbfc;font-size:16px;font-weight:900}td:first-child,th:first-child{text-align:center}tr:last-child td{border-bottom:0}td:last-child,th:last-child{border-right:0}.yes{color:var(--green)}.no,.yes{font-weight:900}.no{color:var(--red)}.pill{display:inline-flex;min-width:62px;justify-content:center;padding:6px 14px;border-radius:8px;font-weight:900}.pill.ok{background:#e4f6ec;color:var(--green)}.pill.bad{background:#fde7e7;color:var(--red)}.view-btn{min-width:122px;height:38px;border-radius:7px;font-size:16px}.pagination{min-height:62px;margin-top:12px;padding:10px 34px;flex:0 0 auto;display:grid;grid-template-columns:1fr auto 170px;align-items:center;grid-gap:24px;gap:24px;border:1px solid var(--line);border-radius:10px;background:var(--surface);box-shadow:var(--shadow)}.pagination>span{color:#475569;font-size:17px}.page-buttons{display:flex;align-items:center;gap:12px}.close-btn,.nav-image,.page-buttons button,.viewer-toolbar button{display:inline-grid;place-items:center;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}.page-buttons button{width:44px;height:40px;font-size:18px}.page-buttons button.active{border-color:var(--green);background:linear-gradient(180deg,#009b59,#007a45);color:#fff}.pagination select{height:44px;border-radius:8px;padding-inline:16px;font-weight:800}.modal-backdrop{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:28px;background:rgba(15,23,42,.66);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.image-viewer,.prediction-modal{position:relative;width:min(1460px,96vw);max-height:92vh;overflow:auto;border-radius:14px;border:1px solid var(--line);background:#fff;box-shadow:0 28px 90px rgba(2,8,23,.32)}.prediction-modal{max-height:calc(100vh - 24px);padding:22px 26px 24px;overflow:hidden}.close-btn{position:absolute;top:32px;right:32px;width:58px;height:58px}.modal-title,.viewer-title{display:flex;align-items:center;gap:22px;padding-right:80px}.title-icon{width:82px;height:82px}.modal-title h2,.viewer-title h2{margin:0;font-size:34px}.prediction-modal .modal-title h2{font-size:24px}.comparison-grid{display:grid;grid-template-columns:minmax(570px,.95fr) minmax(720px,1.2fr);grid-gap:12px;gap:12px;margin-top:24px;align-items:stretch}.comparison-section{min-width:0;overflow:hidden;border:1px solid var(--line);border-radius:10px;background:#fff}.comparison-section h3{height:60px;margin:0;display:grid;place-items:center;border-bottom:4px solid var(--green);font-size:22px}.slots{display:grid;min-height:300px}.original-slots{grid-template-columns:repeat(6,minmax(92px,1fr))}.prediction-slots{grid-template-columns:repeat(6,minmax(96px,1fr))}.slot{display:grid;grid-template-rows:66px 1fr;min-width:0;overflow:hidden;border-right:1px solid var(--line)}.slot:last-child{border-right:0}.slot-label{display:grid;place-items:center;border-bottom:1px solid var(--line);background:#f9fcfb;font-weight:900;font-size:13px;line-height:1.25;text-align:center;overflow-wrap:anywhere}.slot-body{display:grid;place-items:center;min-height:200px;padding:12px 8px;overflow:hidden}.prediction-slots .slot-body{padding:10px 6px}.image-mock{position:relative;overflow:hidden;border:0;border-radius:8px;background:#e7eef5;padding:0}.image-mock img{width:100%;height:100%;display:block;object-fit:cover}.image-mock.thumb{width:min(96px,82%);height:130px}.image-mock.empty{display:grid;place-items:center;border:1px solid var(--line);background:#f8fafc}.empty-image{color:#b7c2ce}.mock-line,.mock-sky,.mock-subject{position:absolute;inset:0}.mock-sky{background:radial-gradient(circle at 22% 25%,rgba(255,255,255,.7),transparent 15%),linear-gradient(180deg,#85c8ff 0 50%,#bec8be 50% 100%)}.label .mock-sky,.large-image.label{background:linear-gradient(140deg,#d2a31f 0 25%,#1447c8 25% 58%,#00437c 58% 100%)}.house .mock-sky,.large-image.house{background:linear-gradient(90deg,#e0d1ba 0 34%,#3f4850 34% 43%,#9a4b1e 43% 100%)}.large-image.pole,.pole .mock-sky{background:linear-gradient(180deg,#8dc9ff 0 58%,#b7b2ac 58% 100%)}.large-image.sky,.sky .mock-sky{background:linear-gradient(180deg,#80c7ff 0 62%,#d7d4cd 62% 100%)}.mock-subject{top:54%;left:10%;width:60%;height:34%;background:rgba(8,38,28,.28);-webkit-clip-path:polygon(0 100%,16% 20%,35% 80%,52% 14%,88% 100%);clip-path:polygon(0 100%,16% 20%,35% 80%,52% 14%,88% 100%)}.mock-line{inset:20% 18% auto auto;width:2px;height:90px;background:rgba(12,47,80,.5);transform:rotate(-20deg)}.not-classified{display:inline-flex;align-items:center;justify-content:center;width:100%;max-width:96px;min-height:46px;padding:2px;color:#5d6877;font-size:11px;font-weight:800;line-height:1.2;text-align:center;white-space:normal;overflow-wrap:normal;word-break:normal}.comments-panel{display:block;margin-top:12px;color:#344054;font-size:14px;font-weight:800}.comments-panel textarea{width:100%;min-height:78px;margin-top:4px;resize:none;border:2px solid var(--green);border-radius:10px;padding:10px;color:var(--ink);font:inherit;font-weight:500}.comments-panel textarea::placeholder{color:#b8c0cb}.comments-panel small{display:block;margin-top:2px;color:#a0a8b4;font-size:13px;font-weight:800;text-align:right}.big-close{display:flex;margin:14px auto 0;width:150px;height:39px;border-radius:8px;font-size:18px}.image-viewer{width:min(1160px,96vw);max-height:calc(100vh - 28px);padding:22px 26px 24px;display:flex;flex-direction:column;overflow:hidden}.viewer-header{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:12px;min-width:0}.image-viewer .viewer-title{flex:1 1;min-width:0;margin-bottom:0;padding-right:0;gap:16px}.image-viewer .title-icon{width:64px;height:64px;flex:0 0 auto}.image-viewer .viewer-title h2{max-width:520px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:24px}.viewer-title p{margin:8px 0 0;color:#77859a;font-size:20px}.viewer-toolbar{display:flex;flex:0 0 auto;justify-content:flex-end;gap:12px;margin-bottom:0;padding-right:0}.viewer-toolbar button{min-width:52px;height:48px;color:var(--green-dark);font-weight:900}.viewer-toolbar .viewer-close{color:var(--ink)}.viewer-stage{position:relative;height:min(530px,calc(100vh - 230px));min-height:360px;display:grid;place-items:center;flex:1 1 auto;overflow:hidden;border:1px solid var(--line);border-radius:10px 10px 0 0;background:#fff}.large-image-wrap{transition:transform .16s ease;transform-origin:center;cursor:default;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.viewer-stage.is-zoomed .large-image-wrap{cursor:-webkit-grab;cursor:grab}.viewer-stage.is-dragging .large-image-wrap{cursor:-webkit-grabbing;cursor:grabbing;transition:none}.large-image{position:relative;width:min(1000px,70vw);aspect-ratio:1.42;overflow:hidden;border-radius:8px}.large-real-image{display:block;max-width:min(900px,70vw);max-height:min(500px,calc(100vh - 260px));width:auto;height:auto;object-fit:contain;border-radius:8px}.black-strip{position:absolute;top:0;left:0;right:0;z-index:1;padding:10px;background:#050505;color:#fff;text-align:center;font-size:25px;font-weight:900}.large-subject{position:absolute;left:10%;bottom:0;width:42%;height:44%;background:rgba(11,30,17,.36);-webkit-clip-path:polygon(0 100%,18% 20%,38% 88%,56% 8%,90% 100%);clip-path:polygon(0 100%,18% 20%,38% 88%,56% 8%,90% 100%)}.large-line{position:absolute;right:22%;top:12%;width:3px;height:70%;background:rgba(24,43,65,.52);transform:rotate(-18deg)}.nav-image{position:absolute;top:50%;z-index:2;width:60px;height:60px;border-radius:999px;color:var(--green);background:#fff;box-shadow:var(--shadow)}.nav-image.left{left:38px}.nav-image.right{right:38px}.viewer-meta{display:flex;gap:20px;padding:16px 20px;border:1px solid var(--line);border-top:0;border-radius:0 0 10px 10px}.viewer-meta span{display:inline-flex;align-items:center;gap:14px;min-height:48px;padding:0 18px;border:1px solid var(--line);border-radius:8px;color:#334155;font-size:16px}.viewer-meta .icon{color:var(--green)}.api-message{max-width:1420px;margin:14px auto 0;color:#92400e;font-weight:700}@media (max-width:1040px){main{padding:0 20px 28px}.top-header{width:calc(100% + 40px);margin-left:-20px}.comparison-grid,.filters-panel,.pagination,.stats-grid{grid-template-columns:1fr}.stats-grid{gap:14px}.table-card{overflow-x:auto}table{min-width:900px}.comparison-section{border-right:0;border-bottom:1px solid var(--line)}.original-slots,.prediction-slots{grid-template-columns:repeat(3,minmax(110px,1fr))}.large-image{width:78vw}}body,html{width:100%;min-height:100%;overflow:hidden}#__next{height:100%}