@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@500;600;700;800&family=Noto+Sans+KR:wght@400;500;700;800&family=JetBrains+Mono:wght@500;700&display=swap";:root{--bg: #f1f5f9;--bg-2: #e7eef7;--surface: #ffffff;--surface-soft: #f8fbff;--text: #0f172a;--muted: #64748b;--border: #dce6f3;--border-strong: #c8d6ea;--primary: #2563eb;--primary-strong: #1d4ed8;--primary-soft: #e8f0ff;--success: #059669;--warn: #d97706;--danger: #dc2626;--shadow-sm: 0 4px 10px rgba(15, 23, 42, .04);--shadow-md: 0 16px 32px rgba(15, 23, 42, .08);--radius-lg: 18px;--radius-md: 14px;--radius-sm: 10px}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;color:var(--text);font-family:Noto Sans KR,Plus Jakarta Sans,Pretendard,Apple SD Gothic Neo,Malgun Gothic,Segoe UI,sans-serif;line-height:1.45;background:radial-gradient(1400px 800px at 0% -12%,#dbeafe 0%,transparent 55%),radial-gradient(1000px 700px at 100% 0%,#cffafe 0%,transparent 46%),linear-gradient(180deg,var(--bg-2) 0%,var(--bg) 30%,#f8fafc 100%)}a{color:inherit}input,select,textarea,button{font:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{border:2px solid transparent;border-radius:999px;background:#cbd5e1;background-clip:padding-box}::-webkit-scrollbar-track{background:transparent}.app-shell{display:grid;grid-template-columns:348px minmax(0,1fr);gap:22px;min-height:100vh;max-width:1720px;margin:0 auto;padding:22px}.surface{position:relative;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);animation:fade-up .22s ease-out both}.surface:before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:1px;background:linear-gradient(90deg,rgba(37,99,235,.18),rgba(34,211,238,.28),transparent);pointer-events:none}.app-shell>:not(.sidebar){display:grid;align-content:start;gap:20px;min-width:0}.app-shell>:not(.sidebar)>*{min-width:0}.sidebar{position:sticky;top:22px;align-self:start}.sidebar-head{padding:20px 20px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#fff,#f8fbff)}.kicker{margin:0 0 8px;font-size:12px;font-weight:700;color:#64748b;letter-spacing:.01em}.sidebar-head h1{margin:0;font-size:30px;font-weight:800;letter-spacing:-.02em}.sub{margin-top:6px;font-size:14px;color:#475569;line-height:1.5}.badge-wrap{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.badge{display:inline-flex;align-items:center;border:1px solid #bfdbfe;border-radius:999px;background:var(--primary-soft);color:#1e3a8a;padding:4px 10px;font-size:12px;font-weight:700;line-height:1}.meta-line{display:flex;flex-wrap:wrap;gap:8px 12px;margin-top:10px;font-size:12px;color:#64748b}.meta-line span{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border:1px solid var(--border);border-radius:999px;background:#fff}.sidebar-body{padding:16px;display:flex;flex-direction:column;gap:12px}.stack{display:flex;flex-direction:column;gap:10px}.side-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-soft);padding:14px;box-shadow:inset 0 1px #fff}.label{margin:0;font-size:12px;font-weight:700;color:var(--muted);text-transform:none;letter-spacing:0}.row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.row>*{min-width:0}input[type=text],input[type=date],input[type=file],select,textarea{width:100%;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:#fff;color:var(--text);transition:border-color .16s ease,box-shadow .16s ease}input[type=text],input[type=date],select{min-height:42px;padding:0 12px}input[type=file]{padding:10px 12px;font-size:13px}textarea{min-height:110px;padding:10px 12px;resize:vertical;line-height:1.45}input[type=text]:focus,input[type=date]:focus,input[type=file]:focus,select:focus,textarea:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 4px #3b82f626}button{border:0;cursor:pointer;transition:transform .15s ease,filter .15s ease,box-shadow .15s ease}button:active{transform:translateY(1px)}button:disabled{cursor:not-allowed;opacity:.6}.btn-primary,.btn-ghost,.btn-danger{min-height:40px;border-radius:11px;font-size:13px;font-weight:700;letter-spacing:.01em}.btn-mini{min-height:32px;padding:0 10px;font-size:12px}.btn-primary{color:#fff;background:linear-gradient(180deg,#3b82f6 0%,var(--primary) 100%);box-shadow:0 10px 22px #2563eb47}.btn-primary:hover{filter:brightness(1.03);transform:translateY(-1px)}.btn-ghost{border:1px solid var(--border-strong);color:#1f2937;background:#fff}.btn-ghost:hover{border-color:#93c5fd;background:#eff6ff}.btn-danger{color:#fff;background:linear-gradient(180deg,#ef4444 0%,var(--danger) 100%);box-shadow:0 10px 20px #dc26263d}.status{min-height:18px;font-size:12px;color:var(--muted)}.status.err{color:var(--danger);font-weight:700}.side-table{border:1px solid var(--border);border-radius:var(--radius-md);background:#fff;overflow:hidden}.side-table table{table-layout:fixed}.side-table th:nth-child(1),.side-table td:nth-child(1){width:52%}.side-table th:nth-child(2),.side-table td:nth-child(2){width:20%}.side-table th:nth-child(3),.side-table td:nth-child(3){width:28%}.side-table-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 10px;border-top:1px solid var(--border);background:#f8fbff}.pager-info{font-size:12px;color:#64748b;font-weight:600}.pager{display:inline-flex;align-items:center;gap:6px}.pager-page{min-width:56px;text-align:center;font-size:12px;font-weight:700;color:#334155}.pager-btn{min-width:48px;min-height:30px;padding:0 10px;border:1px solid var(--border-strong);border-radius:8px;background:#fff;color:#334155;font-size:12px;font-weight:700;line-height:1}.pager-btn:hover:not(:disabled){border-color:#93c5fd;background:#eff6ff}table{width:100%;border-collapse:separate;border-spacing:0}.side-table thead th{padding:10px 12px;border-bottom:1px solid var(--border);background:#f8fbff;font-size:12px;font-weight:700;color:#475569;letter-spacing:0;text-transform:none;text-align:left}.side-table tbody td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:top}.case-file{display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.case-created{white-space:nowrap;font-size:12px;color:#475569}.export-opt-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:6px}.export-list{display:grid;gap:8px;max-height:230px;overflow:auto}.export-item{border:1px solid var(--border);border-radius:10px;background:#fff;padding:8px 10px;display:grid;gap:4px}.export-item>div:first-child{display:flex;align-items:center;gap:6px}.export-actions{display:flex;justify-content:flex-end}.status-chip{display:inline-flex;align-items:center;min-height:20px;padding:0 8px;border-radius:999px;border:1px solid transparent;font-size:11px;font-weight:700;line-height:1}.status-running{color:#92400e;background:#fffbeb;border-color:#fde68a}.status-completed{color:#166534;background:#ecfdf3;border-color:#bbf7d0}.status-failed{color:#991b1b;background:#fef2f2;border-color:#fecaca}.status-pending{color:#1e3a8a;background:#eff6ff;border-color:#bfdbfe}.side-table tbody tr{cursor:pointer;transition:background-color .14s ease}.side-table tbody tr:hover{background:#eef5ff}.side-table tbody tr:last-child td{border-bottom:0}.active-row{background:#dbeafe!important}.mono{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-size:12px}.muted{color:var(--muted)}.surface .muted{font-size:12px}.uploaded,.predicted,.reviewed,.annotated,.status-uploaded,.status-predicted,.status-reviewed,.status-annotated{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 10px;border:1px solid transparent;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:0;text-transform:none}.uploaded,.status-uploaded{color:#1e3a8a;background:#eaf2ff;border-color:#bfdbfe}.predicted,.status-predicted{color:#0f766e;background:#e6fffb;border-color:#99f6e4}.reviewed,.status-reviewed{color:#166534;background:#ecfdf3;border-color:#bbf7d0}.annotated,.status-annotated{color:#9a3412;background:#fff7ed;border-color:#fed7aa}.toolbar,.action-row,.btn-row{display:flex;flex-wrap:wrap;gap:10px}.grid-2,.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.panel,.card,.main-card,.viewer-card,.result-card,.editor-card{border:1px solid var(--border);border-radius:var(--radius-md);background:#fff;box-shadow:var(--shadow-sm)}.panel-head,.card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.panel-body,.card-body{padding:16px}.panel-title{margin:0;font-size:15px;font-weight:800}.image-stage,.image-pane,.viewer-stage,.preview-stage,.canvas-wrap{position:relative;display:grid;place-items:center;min-height:320px;border:1px solid var(--border);border-radius:12px;background:linear-gradient(45deg,rgba(148,163,184,.08) 25%,transparent 25%),linear-gradient(-45deg,rgba(148,163,184,.08) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(148,163,184,.08) 75%),linear-gradient(-45deg,transparent 75%,rgba(148,163,184,.08) 75%),#f8fafc;background-size:24px 24px;background-position:0 0,0 12px,12px -12px,-12px 0;overflow:hidden}.image-stage img,.image-pane img,.viewer-stage img,.preview-stage img,.canvas-wrap canvas{max-width:100%;max-height:100%;display:block}.loading{color:var(--muted)}.spinner{width:20px;height:20px;border:2px solid #bfdbfe;border-top-color:var(--primary);border-radius:999px;animation:spin .8s linear infinite}.workspace{display:flex;flex-direction:column;min-height:calc(100vh - 44px)}.workspace-head{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px 14px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#fff,#f8fbff)}.workspace-head h2{margin:0;font-size:30px;font-weight:800;letter-spacing:-.02em}.workspace-head .sub{margin-top:6px}.workspace-actions{display:flex;flex-wrap:wrap;gap:8px}.action-check{display:inline-flex;align-items:center;gap:6px;min-height:40px;padding:0 12px;border:1px solid var(--border-strong);border-radius:11px;background:#fff;color:#334155;font-size:13px;font-weight:600}.action-check input{margin:0}.content-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:14px 16px 0}.content-grid.bottom-pad{padding-bottom:16px}.full-span{grid-column:1 / -1}.card{overflow:hidden}.card-title{padding:11px 14px;border-bottom:1px solid var(--border);background:#f8fbff;font-size:13px;font-weight:800;color:#1f2937;letter-spacing:.03em}.img-wrap{position:relative;display:grid;place-items:center;min-height:210px;border:1px solid var(--border);border-radius:12px;background:linear-gradient(45deg,rgba(148,163,184,.08) 25%,transparent 25%),linear-gradient(-45deg,rgba(148,163,184,.08) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(148,163,184,.08) 75%),linear-gradient(-45deg,transparent 75%,rgba(148,163,184,.08) 75%),#f8fafc;background-size:24px 24px;background-position:0 0,0 12px,12px -12px,-12px 0;overflow:hidden}.img-wrap img{max-width:100%;max-height:100%;width:100%;height:100%;object-fit:contain;display:block}.seg-grid{display:grid;grid-template-columns:minmax(280px,1fr) minmax(300px,1.2fr);gap:14px;align-items:start}.table-wrap{border:1px solid var(--border);border-radius:12px;background:#fff;overflow:auto}.table-wrap table{min-width:100%}.table-wrap thead th{position:sticky;top:0;z-index:1;background:#f8fbff}.card td,.card th{padding:10px 11px;border-bottom:1px solid var(--border);text-align:left;font-size:13px;vertical-align:top}.card th{font-weight:800;color:#334155}.card tr:last-child td{border-bottom:0}.max-seg{max-height:300px}.link-mini{color:#1d4ed8;font-size:12px;font-weight:700;text-decoration:none}.link-mini:hover{text-decoration:underline}.prediction-list{display:grid;gap:9px}.prediction-item{border:1px solid var(--border);border-radius:10px;background:#fff;padding:9px 10px;display:grid;grid-template-columns:1fr auto;gap:7px 10px;align-items:center;font-size:13px}.prediction-item.top{border-color:#bfdbfe;background:#f0f7ff}.bar{grid-column:1 / -1;height:7px;border-radius:999px;background:#e2e8f0;overflow:hidden}.bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#60a5fa,#2563eb)}.check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 10px}.check-item{display:flex;align-items:center;gap:7px;min-width:0;font-size:13px;color:#334155}.check-item input{margin:0}.btn-ok{min-height:40px;border-radius:11px;font-size:13px;font-weight:700;color:#fff;background:linear-gradient(180deg,#22c55e,#16a34a);box-shadow:0 8px 18px #16a34a3d}.annot-shell{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(280px,.9fr);gap:14px;align-items:start}.annot-canvas{display:flex;flex-direction:column;gap:10px}.annot-canvas>.row{grid-template-columns:minmax(200px,1.4fr) repeat(4,minmax(82px,1fr));gap:8px}.image-stage{min-height:360px;cursor:crosshair}.image-stage img{width:100%;height:100%;object-fit:contain}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.ann-side{display:flex;flex-direction:column;gap:10px}.ann-side-head,.ann-side-foot{border:1px solid var(--border);border-radius:11px;background:#f8fbff;padding:10px}.section-title{font-size:13px}.mini{font-size:12px}.ann-list{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow:auto}.ann-item{border:1px solid var(--border);border-radius:11px;background:#fff;padding:9px 10px;cursor:pointer;transition:border-color .16s ease,background-color .16s ease}.ann-item:hover{border-color:#93c5fd;background:#f5f9ff}.ann-item.active{border-color:#60a5fa;background:#eaf3ff}.version-list{margin-top:8px;display:grid;gap:6px;max-height:170px;overflow:auto}.version-entry{border:1px dashed var(--border-strong);border-radius:8px;background:#fff;padding:7px 8px;font-size:12px;color:#475569}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1400px){.app-shell{grid-template-columns:320px minmax(0,1fr)}}@media (max-width: 1180px){.app-shell{grid-template-columns:minmax(0,1fr)}.sidebar{position:static;height:auto}.sidebar-body{overflow:visible}.workspace{min-height:auto}.workspace-head{flex-direction:column;align-items:flex-start}.content-grid,.seg-grid,.annot-shell{grid-template-columns:minmax(0,1fr)}.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 860px){.app-shell{padding:14px;gap:14px}.row,.grid-2,.grid-3,.two-col,.check-grid,.annot-canvas>.row{grid-template-columns:minmax(0,1fr)}.sidebar-head{padding:16px}.workspace-head{padding:14px 14px 10px}.workspace-head h2{font-size:26px}.content-grid{padding:10px 10px 0;gap:10px}.content-grid.bottom-pad{padding-bottom:10px}.side-card,.panel-body,.card-body{padding:12px}}
