:root{--bg: #EEF0F3;--surface: #FFFFFF;--surface-2: #F4F6F8;--surface-3: #E8EAED;--border: #D0D3D9;--border-light: #E4E6EA;--text: #302E40;--text-muted: #6B7280;--text-subtle: #9CA3AF;--primary: #00A0C6;--primary-hover: #0090B4;--primary-dark: #00455D;--primary-light: #00A0C614;--success: #16a34a;--success-light: #16a34a14;--danger: #dc2626;--danger-light: #dc262614;--warning: #d97706;--warning-light: #d9770614;--radius: 8px;--radius-sm: 5px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 8px rgba(0,0,0,.09);--font: "Segoe UI", system-ui, -apple-system, Arial, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:220px;flex-shrink:0;background:var(--primary-dark);display:flex;flex-direction:column;overflow-y:auto}.sidebar-brand{padding:0 16px;height:64px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.12)}.sidebar-brand-text{display:flex;flex-direction:column}.sidebar-brand-text .brand-main{font-size:13px;font-weight:700;color:#fff;line-height:1.2}.sidebar-brand-text .brand-sub{font-size:10px;color:#ffffff8c;letter-spacing:.04em;text-transform:uppercase}.sidebar-nav{flex:1;padding:10px 0}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:13px;color:#ffffffa6;cursor:pointer;border:none;background:none;width:100%;text-align:left;text-decoration:none;transition:background .1s,color .1s}.sidebar-link:hover{background:#ffffff14;color:#fff;text-decoration:none}.sidebar-link.active{background:#00a0c647;color:#fff;font-weight:600}.sidebar-user{padding:12px 16px;border-top:1px solid rgba(255,255,255,.12);font-size:12px;color:#ffffff80}.main-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;background:var(--bg)}.page{padding:24px;max-width:1320px;width:100%}.page-header{margin-bottom:20px}.page-header h1{font-size:20px;font-weight:700;margin-bottom:4px;color:var(--primary-dark)}.page-header p{color:var(--text-muted);font-size:13px}.breadcrumb{font-size:12px;color:var(--text-muted);margin-bottom:8px}.breadcrumb a{color:var(--text-muted)}.breadcrumb a:hover{color:var(--primary)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.card+.card{margin-top:12px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:background .12s,border-color .12s,color .12s,box-shadow .12s;white-space:nowrap;line-height:1.4;box-shadow:0 1px 2px #0000000f}.btn:hover{background:var(--surface-3);border-color:#bbbfc8;box-shadow:0 2px 4px #00000017}.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 1px 3px #00a0c64d}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 2px 6px #00a0c666}.btn-dark{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff;box-shadow:0 1px 3px #00455d4d}.btn-dark:hover{background:#005070;border-color:#005070;box-shadow:0 2px 6px #00455d66}.btn-success{background:var(--success);border-color:var(--success);color:#fff;box-shadow:0 1px 3px #16a34a59}.btn-success:hover{background:#15803d;border-color:#15803d;box-shadow:0 2px 6px #16a34a73}.btn-danger{background:var(--danger-light);border-color:#fca5a5;color:var(--danger)}.btn-danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}.btn-sm{padding:4px 9px;font-size:12px}.btn-lg{padding:9px 18px;font-size:14px;font-weight:600}.btn-ghost{background:transparent;border-color:transparent;box-shadow:none}.btn-ghost:hover{background:var(--surface-3)}@keyframes btn-pulse{0%,to{box-shadow:0 1px 3px #16a34a59}50%{box-shadow:0 0 0 4px #16a34a2e,0 1px 3px #16a34a59}}.btn-success.btn-pulse{animation:btn-pulse 1.6s ease-in-out infinite}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.05em}input,select,textarea{width:100%;padding:7px 10px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font);transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}input::placeholder{color:var(--text-subtle)}textarea{resize:vertical;min-height:80px}input[type=checkbox]{width:14px;height:14px;padding:0;cursor:pointer;accent-color:var(--primary)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.flex{display:flex}.flex-col{flex-direction:column}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.04em}.badge-pass{background:var(--success-light);color:var(--success);border:1px solid #86efac}.badge-fail{background:var(--danger-light);color:var(--danger);border:1px solid #fca5a5}.badge-warn{background:var(--warning-light);color:var(--warning);border:1px solid #fcd34d}.badge-neutral{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:7px 10px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border);background:var(--surface-2)}.table td{padding:8px 10px;border-bottom:1px solid var(--border-light);font-size:13px}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#f0f9fb}.divider{height:1px;background:var(--border);margin:12px 0}.text-muted{color:var(--text-muted)}.text-sm{font-size:12px}.text-xs{font-size:11px}.font-mono{font-family:var(--font-mono)}.font-bold{font-weight:700}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:9999}.toast{padding:10px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;min-width:240px;max-width:400px;box-shadow:var(--shadow-md);animation:slide-in .2s ease;display:flex;align-items:center;gap:8px}.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--danger);color:#fff}.toast-info{background:var(--primary-dark);color:#fff}@keyframes slide-in{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .65s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .65s linear infinite}.loading-center{display:flex;justify-content:center;align-items:center;padding:60px}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state h3{font-size:16px;margin-bottom:6px;color:var(--text)}.empty-state p{font-size:13px}.editor-page{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}.editor-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);flex-shrink:0;gap:12px}.editor-topbar-left{display:flex;flex-direction:column;gap:2px;min-width:0}.editor-topbar-title{font-size:15px;font-weight:700;color:var(--primary-dark)}.editor-topbar-sub{font-size:12px;color:var(--text-muted)}.editor-tabnav{display:flex;align-items:stretch;background:var(--surface);border-bottom:2px solid var(--border);flex-shrink:0;padding:0 16px}.editor-tab{padding:10px 18px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border:none;background:none;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .12s,border-color .12s;white-space:nowrap}.editor-tab:hover{color:var(--text)}.editor-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.editor-body{display:flex;flex:1;overflow:hidden;gap:0}.editor-left{width:460px;flex-shrink:0;overflow-y:auto;padding:14px}.editor-right{flex:1;min-width:300px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.editor-right-header{padding:10px 14px;border-bottom:1px solid var(--border);font-size:11px;font-weight:700;color:var(--primary-dark);text-transform:uppercase;letter-spacing:.06em;display:flex;justify-content:space-between;align-items:center;background:#f0f9fb}.editor-right-body{flex:1;overflow-y:auto;padding:12px}.svg-drawing-wrap{border-radius:6px;overflow:hidden;border:1px solid var(--border)}.svg-drawing-wrap svg{width:100%;height:auto;display:block}.editor-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-bottom:12px}.editor-panel-header{padding:9px 14px;border-bottom:1px solid var(--border);font-size:11px;font-weight:700;color:var(--primary-dark);text-transform:uppercase;letter-spacing:.06em;display:flex;justify-content:space-between;align-items:center;background:var(--surface-2)}.editor-panel-body{padding:14px}.svc-card{border:1px solid var(--border);border-radius:6px;margin-bottom:10px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}.svc-card-header{display:flex;gap:5px;align-items:center;padding:6px 10px;background:var(--surface-2);border-bottom:1px solid var(--border-light);cursor:pointer}.svc-card-body{padding:10px 12px}.inline-check{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;padding:5px 10px;border-radius:5px;border:1.5px solid var(--border);background:var(--surface);transition:background .1s,border-color .1s,color .1s;box-shadow:0 1px 2px #0000000a}.inline-check:hover{background:var(--surface-2);border-color:#a0cfe0;color:var(--text)}.inline-check:has(input:checked){background:#e0f7ff;border-color:var(--primary);color:var(--primary-dark);font-weight:600;box-shadow:0 0 0 2px #00a0c61f}.inline-check input{width:15px;height:15px;cursor:pointer;accent-color:var(--primary);flex-shrink:0}.seg-group{display:inline-flex;border-radius:var(--radius-sm);border:1.5px solid var(--border);overflow:hidden;box-shadow:0 1px 2px #0000000d}.seg-btn{padding:5px 13px;font-size:12px;font-weight:500;border:none;border-right:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s;white-space:nowrap;line-height:1.4}.seg-btn:last-child{border-right:none}.seg-btn:hover:not(.seg-active){background:var(--surface-2);color:var(--text)}.seg-active{background:var(--primary);color:#fff;font-weight:600;box-shadow:inset 0 1px 2px #00000014}.check-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border-light)}.check-row:last-child{border-bottom:none}.load-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.tier-result-block{background:var(--surface);border:1px solid var(--border);border-radius:6px;margin-bottom:10px;overflow:hidden}.tier-result-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:13px;font-weight:600}.tier-result-body{padding:10px 12px}.defl-table{width:100%;border-collapse:collapse;font-size:11px;font-family:var(--font-mono)}.defl-table th{padding:4px 8px;background:var(--surface-2);color:var(--text-muted);font-weight:600;border:1px solid var(--border-light)}.defl-table td{padding:3px 8px;border:1px solid var(--border-light);text-align:right}.defl-table td:first-child{text-align:left}.fill-bar-wrap{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:4px}.fill-bar{height:100%;border-radius:3px;transition:width .3s}.fill-ok{background:var(--success)}.fill-warn{background:var(--warning)}.fill-over{background:var(--danger)}.config-subtab-nav{display:flex;gap:4px;flex-wrap:wrap;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px}.config-subtab-btn{padding:4px 10px;font-size:11px;font-weight:500;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .1s;white-space:nowrap}.config-subtab-btn:hover{background:var(--surface-2);color:var(--text)}.config-subtab-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.chat-messages{display:flex;flex-direction:column;gap:10px;padding:16px 0}.chat-bubble{display:flex;gap:8px;align-items:flex-start}.chat-bubble.user{flex-direction:row-reverse}.chat-bubble-body{max-width:80%;padding:10px 14px;border-radius:10px;font-size:13px;line-height:1.5}.chat-bubble.ai .chat-bubble-body{background:var(--surface-2);border:1px solid var(--border);border-radius:2px 10px 10px}.chat-bubble.user .chat-bubble-body{background:var(--primary);color:#fff;border-radius:10px 2px 10px 10px}.chat-bubble.error .chat-bubble-body{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.chat-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.chat-avatar.ai{background:var(--primary-light);color:var(--primary-dark)}.chat-avatar.user{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.chat-input-row{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:var(--surface);position:sticky;bottom:0}.chat-input-row textarea{flex:1;resize:none;min-height:40px;max-height:120px;border-radius:8px;padding:8px 12px;font-size:13px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit}.chat-input-row textarea:focus{outline:none;border-color:var(--primary)}.lib-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}@media (max-width: 1100px){.editor-left{width:380px}}@media (max-width: 900px){.editor-left{width:320px}.editor-right{min-width:200px}}@media (max-width: 768px){.sidebar{width:52px}.sidebar-brand-text,.sidebar-link span,.sidebar-user{display:none}.grid-2,.grid-3{grid-template-columns:1fr}}@keyframes pulse{0%,to{opacity:1;transform:translate(-50%,-100%) scale(1)}50%{opacity:.7;transform:translate(-50%,-100%) scale(1.15)}}
