:root{--bg: #f7f4ec;--panel: rgba(255, 255, 255, .86);--panel-strong: #ffffff;--ink: #15212b;--muted: #5b6872;--line: rgba(21, 33, 43, .1);--brand: #0a5c63;--brand-strong: #063f44;--accent: #cb6b38;--success: #1d7a66;--warning: #b96d27;--danger: #c04a52;--shadow: 0 28px 60px rgba(16, 30, 40, .08);font-family:Avenir Next,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}body{margin:0;color:var(--ink);background:radial-gradient(circle at top left,rgba(10,92,99,.18),transparent 28%),radial-gradient(circle at right top,rgba(203,107,56,.12),transparent 24%),linear-gradient(180deg,#fcfaf4,#eef2ea)}button,textarea,select{font:inherit}button{cursor:pointer}.security-demo-shell{min-height:100vh;padding:20px;display:grid;gap:16px}.hero,.panel{border:1px solid var(--line);border-radius:24px;background:var(--panel);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow)}.hero{padding:20px 22px;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(240px,.75fr);gap:16px}.hero-kicker,.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--brand);font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}.hero h1,.panel h2{margin:0;font-size:clamp(24px,3vw,34px);line-height:1.05}.hero p{max-width:700px;color:var(--muted);line-height:1.65;font-size:14px;margin:12px 0 0}.hero-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;align-self:end}.stat-card{padding:14px 16px;border-radius:16px;background:linear-gradient(180deg,#fffffff5,#f4f8f6c7);border:1px solid rgba(10,92,99,.08);display:grid;gap:6px}.stat-card span{color:var(--muted);font-size:12px}.stat-card strong{font-size:18px;color:var(--brand-strong)}.error-banner{border-radius:16px;padding:14px 18px;background:#c04a521f;border:1px solid rgba(192,74,82,.18);color:#8d2a31}.security-layout{display:grid;grid-template-columns:minmax(360px,.95fr) minmax(0,1.35fr);gap:16px}.panel{padding:20px}.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:18px}.panel h2{font-size:24px}.status-dot,.result-badge{padding:8px 12px;border-radius:999px;font-size:12px;white-space:nowrap}.status-dot{background:#0a5c6314;color:var(--brand)}.result-head-actions{display:flex;align-items:center;gap:10px}.result-badge{background:#15212b0f;color:var(--muted)}.result-badge-matched{background:#1d7a661f;color:var(--success)}.result-badge-no_hit{background:#b96d271f;color:var(--warning)}.result-badge-pending{background:#0a5c631a;color:var(--brand)}.result-badge-error{background:#c04a521f;color:var(--danger)}.query-form{display:grid;gap:14px}.sample-select-wrap{display:grid;gap:8px}.sample-select-label{color:var(--muted);font-size:12px}.sample-select{width:100%;border:1px solid rgba(10,92,99,.12);border-radius:14px;padding:12px 14px;background:#fffffff0;color:var(--ink);appearance:none}.query-form textarea{width:100%;resize:vertical;min-height:132px;border:1px solid rgba(10,92,99,.12);border-radius:18px;padding:16px 18px;background:#fffffff0;color:var(--ink);line-height:1.6}.query-actions{display:flex;gap:10px}.primary-action,.secondary-action{border-radius:14px;padding:12px 16px;border:1px solid transparent}.primary-action{background:linear-gradient(135deg,var(--brand) 0%,#0c6d74 100%);color:#fff;box-shadow:0 16px 26px #0a5c632e}.secondary-action{background:#fffc;border-color:#15212b14;color:var(--ink)}.secondary-action.compact{padding:8px 12px}.sample-grid,.sources-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.sample-grid{margin-top:18px}.sample-card,.source-card{border:1px solid rgba(10,92,99,.08);border-radius:18px;padding:16px;background:linear-gradient(180deg,#fffffff5,#f5f8f6c7);text-align:left}.sample-card span,.source-card span,.query-summary-label,.strict-output-head small{color:var(--muted);font-size:12px}.sample-card strong,.source-card strong{display:block;margin-top:8px;color:var(--brand-strong);line-height:1.55;font-size:15px}.source-card p{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.55}.empty-state,.no-hit-card,.strict-output,.query-summary,.progress-card{border-radius:18px;border:1px solid rgba(21,33,43,.08);background:#ffffffd1}.empty-state,.no-hit-card{padding:24px}.empty-state h3,.no-hit-card h3{margin:0 0 8px;font-size:20px}.empty-state p,.no-hit-card p{margin:0;color:var(--muted);line-height:1.65}.query-summary{padding:16px 18px;display:grid;gap:6px;margin-bottom:14px}.query-summary strong{font-size:16px;line-height:1.55}.query-summary small{color:var(--brand)}.transport-note{color:var(--muted);font-size:12px;line-height:1.5}.table-shell{overflow:auto;border-radius:18px;border:1px solid rgba(10,92,99,.12);background:#fffffff5}.result-table{width:100%;border-collapse:collapse;min-width:720px}.result-table th,.result-table td{padding:14px 16px;border-bottom:1px solid rgba(21,33,43,.08);vertical-align:top;text-align:left;line-height:1.55}.result-table thead th{background:#0a5c630f;color:var(--brand-strong);font-size:13px}.result-table tbody td:first-child{width:72px;color:var(--brand);font-weight:700}.strict-output{margin-top:14px;overflow:hidden}.progress-card{margin-top:14px;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px}.strict-output-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(21,33,43,.08)}.strict-output-head span{font-weight:700}.strict-output pre{margin:0;padding:16px;white-space:pre-wrap;line-height:1.65;font-family:SFMono-Regular,Menlo,monospace;font-size:13px}.progress-copy{display:flex;align-items:flex-start;gap:12px}.progress-copy strong{display:block;line-height:1.4;font-size:15px}.progress-copy p{margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.55}.progress-dot{width:10px;height:10px;border-radius:999px;margin-top:5px;background:#15212b2e;box-shadow:0 0 0 8px #15212b0d;flex:0 0 auto}.progress-dot-running{background:var(--brand);box-shadow:0 0 0 8px #0a5c6314}.progress-dot-done{background:var(--success);box-shadow:0 0 0 8px #1d7a6614}.progress-dot-error{background:var(--danger);box-shadow:0 0 0 8px #c04a5214}.progress-dot-quiet{background:var(--warning);box-shadow:0 0 0 8px #b96d2714}.progress-tags{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.progress-tag{padding:7px 10px;border-radius:999px;background:#0a5c6312;color:var(--brand-strong);font-size:12px;white-space:nowrap}.sources-panel{display:grid;gap:16px}@media(max-width:1080px){.hero,.security-layout,.hero-stats,.sample-grid,.sources-grid{grid-template-columns:1fr}.security-demo-shell{padding:14px}.panel,.hero{padding:16px}.progress-card{flex-direction:column;align-items:flex-start}.progress-tags{justify-content:flex-start}}
