:root{--bg:#f3ece1;--bg-2:#ede4d6;--surface:#fffdf8;--surface-2:#faf5ec;--ink:#2c2823;--ink-2:#5f574c;--muted:#948a7b;--faint:#b9ae9c;--border:#e4d9c8;--border-2:#d8cbb6;--accent:#b5613f;--accent-deep:#974d30;--accent-soft:#f0ddd0;--accent-tint:#f7ece4;--sage:#6f7d5f;--sage-soft:#e4e8da;--ok:#5b7a4f;--ok-soft:#e3ecd9;--warn:#b3812f;--warn-soft:#f4e7cd;--danger:#b04a3a;--danger-soft:#f3dcd5;--info:#4f6d82;--info-soft:#dde7ee;--radius:14px;--radius-sm:9px;--radius-lg:20px;--shadow:0 1px 2px #362b1c0a, 0 6px 20px #362b1c0f;--shadow-lg:0 12px 40px #362b1c24;--ring:0 0 0 3px var(--accent-soft);--font-display:"Spectral", Georgia, serif;--font-ui:"Hanken Grotesk", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace}*{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}body{font-family:var(--font-ui);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-size:14px;line-height:1.45}#root{height:100%}button{cursor:pointer;font-family:inherit}input,select,textarea{color:var(--ink);font-family:inherit;font-size:14px}::selection{background:var(--accent-soft)}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-thumb{border:3px solid var(--bg);background:#d6c9b4;border-radius:20px}::-webkit-scrollbar-thumb:hover{background:#c6b89f}.app{height:100%;display:flex;overflow:hidden}.sidebar{background:var(--bg-2);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:4px;width:248px;padding:18px 14px;display:flex}.brand{align-items:center;gap:11px;padding:8px 8px 16px;display:flex}.brand-mark{background:linear-gradient(150deg,var(--accent),var(--accent-deep));color:#fff;width:40px;height:40px;font-family:var(--font-display);border-radius:12px;flex-shrink:0;place-items:center;font-size:19px;font-weight:600;display:grid;box-shadow:0 3px 8px #974d304d}.brand-name{font-family:var(--font-display);color:var(--ink);font-size:18px;font-weight:600;line-height:1.1}.brand-tag{color:var(--muted);letter-spacing:.02em;font-size:11px}.nav-label{letter-spacing:.1em;text-transform:uppercase;color:var(--faint);padding:14px 10px 6px;font-size:10.5px;font-weight:600}.nav-item{color:var(--ink-2);text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:11px;width:100%;padding:9px 11px;font-size:13.5px;font-weight:500;transition:background .12s,color .12s;display:flex;position:relative}.nav-item:hover{background:var(--surface-2);color:var(--ink)}.nav-item.active{background:var(--surface);color:var(--accent-deep);box-shadow:var(--shadow);font-weight:600}.nav-item svg{width:18px;height:18px;color:var(--muted);flex-shrink:0}.nav-item.active svg{color:var(--accent)}.nav-badge{background:var(--accent-soft);color:var(--accent-deep);font-size:11px;font-weight:600;font-family:var(--font-mono);border-radius:20px;margin-left:auto;padding:1px 7px}.sidebar-foot{border-top:1px solid var(--border);margin-top:auto;padding-top:12px}.user-chip{border-radius:10px;align-items:center;gap:10px;padding:8px;display:flex}.user-chip:hover{background:var(--surface-2)}.avatar{background:var(--sage);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:grid}.main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;height:64px;padding:0 28px;display:flex}.page-title{font-family:var(--font-display);color:var(--ink);font-size:22px;font-weight:600}.search{background:var(--surface);border:1px solid var(--border);width:300px;color:var(--muted);border-radius:10px;align-items:center;gap:9px;padding:8px 13px;transition:border .12s,box-shadow .12s;display:flex}.search:focus-within{border-color:var(--accent);box-shadow:var(--ring)}.search input{width:100%;color:var(--ink);background:0 0;border:none;outline:none}.search svg{flex-shrink:0;width:16px;height:16px}.content{flex:1;padding:28px;overflow-y:auto}.content-narrow{max-width:1180px;margin:0 auto}.btn{white-space:nowrap;border:1px solid #0000;border-radius:10px;align-items:center;gap:7px;padding:9px 15px;font-size:13.5px;font-weight:600;transition:all .13s;display:inline-flex}.btn svg{width:16px;height:16px}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 6px #974d3040}.btn-primary:hover{background:var(--accent-deep)}.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--border-2)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--faint)}.btn-subtle{color:var(--ink-2);background:0 0}.btn-subtle:hover{background:var(--surface-2)}.btn-sm{border-radius:8px;padding:6px 11px;font-size:12.5px}.btn-sm svg{width:14px;height:14px}.btn-danger{background:var(--danger-soft);color:var(--danger)}.btn-danger:hover{background:#ecc8be}.icon-btn{border:1px solid var(--border-2);background:var(--surface);width:34px;height:34px;color:var(--ink-2);border-radius:9px;place-items:center;transition:all .12s;display:grid}.icon-btn:hover{background:var(--surface-2);color:var(--ink)}.icon-btn svg{width:17px;height:17px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:20px}.section-title{font-family:var(--font-display);color:var(--ink);font-size:17px;font-weight:600}.muted{color:var(--muted)}.mono{font-family:var(--font-mono)}.badge{letter-spacing:.01em;white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge .dot{border-radius:50%;width:6px;height:6px}.b-ok{background:var(--ok-soft);color:#3f5836}.b-warn{background:var(--warn-soft);color:#7e5a18}.b-danger{background:var(--danger-soft);color:#8a3326}.b-info{background:var(--info-soft);color:#3a505f}.b-accent{background:var(--accent-soft);color:var(--accent-deep)}.b-sage{background:var(--sage-soft);color:#4d5840}.b-neutral{background:var(--bg-2);color:var(--ink-2)}.serial{font-family:var(--font-mono);letter-spacing:.02em;background:var(--accent-tint);color:var(--accent-deep);border:1px solid var(--accent-soft);border-radius:7px;padding:2px 8px;font-size:12.5px;font-weight:600;display:inline-block}.serial.mother{background:var(--sage-soft);color:#42523a;border-color:#cfd6c0}.table{border-collapse:collapse;width:100%}.table th{text-align:left;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:11px 14px;font-size:11px;font-weight:600}.table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}.table tbody tr{cursor:pointer;transition:background .1s}.table tbody tr:hover{background:var(--surface-2)}.table tbody tr:last-child td{border-bottom:none}.field{flex-direction:column;gap:6px;display:flex}.label{color:var(--ink-2);font-size:12.5px;font-weight:600}.hint{color:var(--muted);font-size:11.5px}.input,.select,.textarea{border:1px solid var(--border-2);background:var(--surface);width:100%;color:var(--ink);border-radius:10px;outline:none;padding:10px 13px;transition:border .12s,box-shadow .12s}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);box-shadow:var(--ring)}.textarea{resize:vertical;min-height:78px;line-height:1.5}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23948a7b' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:34px}.select-row{align-items:flex-end;gap:8px;display:flex}.combo{position:relative}.combo-add{border:1px dashed var(--border-2);background:var(--surface-2);width:42px;height:42px;color:var(--accent);border-radius:10px;flex-shrink:0;place-items:center;transition:all .12s;display:grid}.combo-add:hover{border-color:var(--accent);background:var(--accent-tint)}.overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#2c28236b;place-items:center;padding:30px;animation:.15s fade;display:grid;position:fixed;inset:0}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;animation:.18s cubic-bezier(.2,.8,.3,1) pop;overflow-y:auto}.modal.wide{max-width:840px}@keyframes pop{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:none}}.modal-head{border-bottom:1px solid var(--border);background:var(--surface);z-index:2;border-radius:var(--radius-lg) var(--radius-lg) 0 0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.modal-title{font-family:var(--font-display);font-size:19px;font-weight:600}.modal-body{padding:24px}.modal-foot{border-top:1px solid var(--border);background:var(--surface);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex;position:sticky;bottom:0}.row{align-items:center;gap:10px;display:flex}.col{flex-direction:column;display:flex}.between{justify-content:space-between;align-items:center;gap:14px;display:flex}.wrap{flex-wrap:wrap}.grid{gap:18px;display:grid}.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}.gap6{gap:6px}.gap8{gap:8px}.gap12{gap:12px}.gap16{gap:16px}.gap20{gap:20px}.gap24{gap:24px}.mt4{margin-top:4px}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mt24{margin-top:24px}.mt28{margin-top:28px}.mb4{margin-bottom:4px}.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}.fg{flex:1}.center{align-items:center}.end{justify-content:flex-end}.start{align-items:flex-start}.t-c{text-align:center}.t-r{text-align:right}.f12{font-size:12px}.f13{font-size:13px}.f15{font-size:15px}.f17{font-size:17px}.f20{font-size:20px}.f24{font-size:24px}.f28{font-size:28px}.f34{font-size:34px}.fw600{font-weight:600}.fw700{font-weight:700}.display{font-family:var(--font-display)}.pointer{cursor:pointer}.divider{background:var(--border);border:none;height:1px;margin:16px 0}.hidden{display:none!important}.ph{background-image:repeating-linear-gradient(45deg, var(--surface-2) 0, var(--surface-2) 10px, var(--bg-2) 10px, var(--bg-2) 20px);color:var(--faint);font-family:var(--font-mono);text-align:center;border-radius:var(--radius-sm);place-items:center;font-size:11px;display:grid;position:relative}.kpi{padding:18px 20px}.kpi-label{color:var(--muted);align-items:center;gap:7px;font-size:12px;font-weight:600;display:flex}.kpi-num{font-family:var(--font-display);color:var(--ink);margin-top:8px;font-size:30px;font-weight:600;line-height:1.1}.kpi-sub{color:var(--muted);margin-top:4px;font-size:12px}.kpi-ic{border-radius:9px;flex-shrink:0;place-items:center;width:30px;height:30px;display:grid}.kpi-ic svg{width:16px;height:16px}.trend-up{color:var(--ok);font-weight:600}.trend-down{color:var(--danger);font-weight:600}.av{color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:grid}.tag{background:var(--bg-2);color:var(--ink-2);border-radius:7px;padding:3px 9px;font-size:11.5px;font-weight:600}.tabs{border-bottom:1px solid var(--border);gap:4px;display:flex}.tab{color:var(--muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 14px;font-size:13.5px;font-weight:600;transition:color .12s}.tab:hover{color:var(--ink)}.tab.active{color:var(--accent-deep);border-bottom-color:var(--accent)}.bar{background:var(--bg-2);border-radius:20px;height:7px;overflow:hidden}.bar>span{background:var(--accent);border-radius:20px;height:100%;display:block}.empty{text-align:center;color:var(--muted);padding:50px 20px}.toast-wrap{z-index:200;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{background:var(--ink);color:#fff;box-shadow:var(--shadow-lg);border-radius:11px;align-items:center;gap:9px;padding:11px 18px;font-size:13.5px;font-weight:600;animation:.2s pop;display:flex}.toast svg{color:#9fd28e;width:16px;height:16px}.tree-node{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;padding:11px 13px;transition:all .13s}.tree-node:hover{border-color:var(--accent);transform:translateY(-1px)}.lineage-line{background:var(--border-2)}.auth-loading{height:100%;color:var(--muted);place-items:center;font-size:14px;display:grid}.auth-screen{background:radial-gradient(1200px 600px at 50% -10%, var(--accent-tint), transparent 60%), var(--bg);place-items:center;height:100%;padding:24px;display:grid}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:380px;box-shadow:var(--shadow-lg);padding:28px;animation:.2s cubic-bezier(.2,.8,.3,1) pop}.auth-brand{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding-bottom:8px;display:flex}.auth-title{font-family:var(--font-display);color:var(--ink);font-size:20px;font-weight:600}.auth-link{color:var(--accent-deep);cursor:pointer;background:0 0;border:none;align-self:center;padding:2px;font-size:13px;font-weight:600}.auth-link:hover{text-decoration:underline}.auth-error{background:var(--danger-soft);color:#8a3326;border-radius:10px;padding:9px 12px;font-size:13px;font-weight:500}.auth-notice{background:var(--ok-soft);color:#3f5836;border-radius:10px;padding:9px 12px;font-size:13px;font-weight:500;line-height:1.4}@media (width<=1080px){.g4,.g3{grid-template-columns:repeat(2,1fr)}}
