*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;margin:0}*{box-sizing:border-box}body{color:#1e293b;background:#f1f5f9;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.app{min-height:100vh}.header{color:#f8fafc;background:#1e293b;padding:12px 24px}.header-top{justify-content:space-between;align-items:center;display:flex}.header h1{margin:0;font-size:18px}.header p{color:#94a3b8;margin:2px 0 0;font-size:12px}.version-badge{color:#94a3b8;background:#334155;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.nav{gap:4px;margin-top:10px;display:flex}.nav button{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #475569;border-radius:4px;padding:5px 12px;font-size:12px}.nav button:hover{color:#f8fafc;background:#334155}.nav button.active{color:#fff;background:#2563eb;border-color:#2563eb}.main-content{padding:16px}.main-layout{align-items:flex-start;gap:16px;display:flex}@media (width<=900px){.main-layout{flex-direction:column}}.panel{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.input-panel{flex:0 0 420px;max-height:calc(100vh - 110px);overflow-y:auto}.results-panel{flex:1;min-width:0}.section-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.section-header h2,.section-header h3{border:none;margin:0;padding:0}h2{border-bottom:1px solid #e2e8f0;margin:0 0 12px;padding-bottom:8px;font-size:16px}h3{color:#475569;margin:16px 0 8px;font-size:14px}fieldset{border:1px solid #e2e8f0;border-radius:6px;margin:0 0 10px;padding:10px}legend{color:#475569;padding:0 4px;font-size:13px;font-weight:600}label{align-items:center;gap:8px;margin:4px 0;font-size:13px;display:flex}input[type=number],input[type=text],input:not([type]){border:1px solid #cbd5e1;border-radius:4px;width:100%;max-width:140px;padding:4px 8px;font-size:13px}input:focus,select:focus{outline-offset:-1px;outline:2px solid #2563eb}select{background:#fff;border:1px solid #cbd5e1;border-radius:4px;padding:4px 6px;font-size:13px}.unit{color:#64748b;white-space:nowrap;font-size:12px}.row{align-items:center;gap:8px;margin:4px 0;display:flex}.span-grid{flex-wrap:wrap;gap:4px 12px;display:flex}.span-label{flex:none}.load-row{background:#f8fafc;border-left:3px solid #cbd5e1;border-radius:4px;flex-wrap:wrap;align-items:center;gap:6px;margin:4px 0;padding:6px 8px;font-size:12px;display:flex}.load-row select,.load-row input{font-size:12px}.btn-sm{cursor:pointer;white-space:nowrap;background:#f8fafc;border:1px solid #cbd5e1;border-radius:4px;padding:4px 10px;font-size:12px}.btn-sm:hover{background:#e2e8f0}.btn-sm.danger{color:#dc2626;border-color:#fca5a5}.btn-sm.danger:hover{background:#fef2f2}.btn-primary{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{cursor:not-allowed;background:#94a3b8}.btn-secondary{color:#1e293b;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;padding:10px 20px;font-size:14px}.btn-secondary:hover{background:#e2e8f0}.button-group{gap:8px;margin-top:12px;display:flex}.toast{border-radius:4px;justify-content:space-between;align-items:center;margin:0 16px;padding:8px 14px;font-size:13px;display:flex}.toast-error{color:#dc2626;background:#fef2f2;border:1px solid #fca5a5}.toast-error button{color:#dc2626;cursor:pointer;background:0 0;border:none;font-weight:700}.toast-success{color:#16a34a;background:#f0fdf4;border:1px solid #86efac}.info-box{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;margin-bottom:10px;padding:8px 12px;font-size:13px}.validation-errors{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5;border-radius:4px;margin-bottom:10px;padding:8px 12px;font-size:13px}.validation-errors ul{margin:4px 0 0;padding-left:18px}.validation-errors li{margin:2px 0}.muted{color:#94a3b8;font-style:italic}.result-meta{color:#475569;background:#f8fafc;border-radius:4px;gap:20px;margin-bottom:14px;padding:8px 12px;font-size:13px;display:flex}.empty-state{text-align:center;color:#64748b;padding:20px}.empty-state p{margin:4px 0}.preset-cards{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:10px;display:flex}.preset-card{cursor:pointer;text-align:left;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;max-width:220px;padding:12px 14px;transition:border-color .15s}.preset-card:hover{background:#eff6ff;border-color:#2563eb}.preset-card strong{margin-bottom:4px;font-size:13px;display:block}.preset-card .muted{font-size:12px;font-style:normal}table{border-collapse:collapse;width:100%;margin-bottom:8px;font-size:13px}th,td{text-align:right;border-bottom:1px solid #e2e8f0;padding:6px 10px}th{color:#475569;background:#f8fafc;font-weight:600}td:first-child,th:first-child{text-align:left}tr.clickable{cursor:pointer}tr.clickable:hover{background:#f8fafc}tr.selected-row{background:#eff6ff;font-weight:600}.project-table td,.project-table th{padding:10px}.diagram-chart{background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin:8px 0;padding:4px}.extraction-detail{font-size:13px}.extraction-grid{grid-template-columns:1fr 1fr;gap:6px 16px;display:grid}.extraction-grid div{padding:2px 0}.confidence-ok{color:#16a34a;font-weight:600}.confidence-low{color:#dc2626;font-weight:600}.extracted-text{white-space:pre-wrap;word-break:break-word;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;max-height:200px;padding:8px;font-size:11px;overflow-y:auto}input[type=file]{font-size:13px}.extraction-method-bar{align-items:center;gap:10px;margin-bottom:8px;display:flex}.method-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:3px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.method-heuristic{color:#475569;background:#f1f5f9;border:1px solid #cbd5e1}.method-ai{color:#1d4ed8;background:#dbeafe;border:1px solid #93c5fd}.method-hybrid{color:#15803d;background:#dcfce7;border:1px solid #86efac}
