:root{--bg:#eef1ed;--surface:#fff;--ink:#18201d;--muted:#66716c;--line:#dce2de;--accent:#206758;--accent-strong:#12483c;--danger:#b03a2e;--ok:#247345;--sans:"Microsoft YaHei UI", "Noto Sans SC", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;font-family:var(--sans);color:var(--ink);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input{font-family:inherit}.app-frame{background:var(--bg);grid-template-columns:248px minmax(0,1fr);min-height:100vh;display:grid}.app-sidebar{border-right:1px solid var(--line);background:#fbfcf9;flex-direction:column;gap:18px;height:100vh;padding:18px 12px;display:flex;position:sticky;top:0}.brand-block{gap:4px;padding:10px 10px 14px;display:grid}.brand-block strong{color:var(--ink);font-size:24px;line-height:1}.brand-block span,.eyebrow,.page-header p,.panel-head p,.panel-footer,.shot-meta dt,.trend-card-head span,.feature-tile span{color:var(--muted)}.main-nav{gap:10px;display:grid}.main-nav button,.shutdown-button,.icon-button,.icon-only,.nudge-button,.segmented button{font:inherit;cursor:pointer;border:0;font-weight:700}.main-nav button,.shutdown-button{color:#4e5b55;text-align:left;background:0 0;border-radius:8px;align-items:center;gap:12px;min-height:48px;padding:0 14px;display:inline-flex}.main-nav button.active{color:#fff;background:linear-gradient(135deg, var(--accent), #0f8a72);box-shadow:0 12px 28px #20675838}.sidebar-stat{border:1px solid var(--line);background:#f4f7f3;border-radius:8px;gap:4px;margin-top:auto;padding:14px;display:grid}.sidebar-stat span{color:var(--muted);font-size:13px}.sidebar-stat strong{color:var(--ink);font-size:28px;line-height:1}.shutdown-button{color:var(--danger);background:#b03a2e14}.content-shell{min-width:0;padding:24px}.page-stack{gap:16px;display:grid}.page-header,.panel-head,.panel-footer{justify-content:space-between;align-items:center;gap:16px;display:flex}.page-header{min-height:92px}.page-header h1,.panel h2{margin:0}.page-header h1{margin-top:2px;font-size:clamp(28px,3.2vw,38px);line-height:1.08}.page-header p,.panel-head p{margin:6px 0 0}.eyebrow{letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:800;display:block}.panel{border:1px solid var(--line);background:var(--surface);border-radius:8px;overflow:hidden;box-shadow:0 18px 45px #1a1f2814}.panel-head,.panel-footer{border-bottom:1px solid var(--line);padding:18px 20px}.panel-head.compact{padding-bottom:14px}.panel-footer{border-top:1px solid var(--line);border-bottom:0;font-size:14px}.toolbar{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.icon-button{border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:0 14px;display:inline-flex}.icon-button:disabled{cursor:wait;opacity:.72}.primary,.icon-button.primary{color:#fff;background:var(--accent)}.secondary{color:var(--accent-strong);background:#2067581a}.ghost{color:var(--muted);border:1px solid var(--line);background:0 0}.window-control{border:1px solid var(--line);min-height:42px;color:var(--muted);background:var(--surface);white-space:nowrap;border-radius:8px;align-items:center;gap:8px;padding:0 12px;font-size:13px;font-weight:700;display:inline-flex}.window-control input{width:64px;padding:7px 8px}input,select{border:1px solid var(--line);width:100%;color:var(--ink);font:inherit;background:#fff;border-radius:8px;padding:10px 11px}input:focus,select:focus{border-color:var(--accent);outline:2px solid #20675833}.trend-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.trend-card{border:1px solid var(--line);background:var(--surface);border-radius:8px;min-height:178px;padding:14px;box-shadow:0 12px 30px #1a1f280f}.trend-card-head{grid-template-columns:auto 1fr;align-items:center;gap:10px;display:grid}.trend-icon{width:36px;height:36px;color:var(--accent);background:#eef5f1;border-radius:8px;place-items:center;display:grid}.trend-card-head strong{color:var(--ink);margin-top:3px;font-size:24px;line-height:1;display:block}.trend-chart{width:100%;height:106px;margin-top:10px}.trend-chart line{stroke:#d9dfd6}.trend-chart polyline{fill:none;stroke:var(--accent);stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.trend-chart circle{fill:#f4b24e;stroke:#fff;stroke-width:1.8px}.analysis-grid{grid-template-columns:minmax(0,1fr) 330px;align-items:start;gap:16px;display:grid}.cluster-layout{background:#f7f8f4;grid-template-columns:minmax(0,1fr) 360px;gap:16px;padding:16px;display:grid}.cluster-map-stage{min-height:360px;position:relative}.cluster-map{width:100%;height:100%;min-height:inherit;border:1px solid var(--line);background:#fbfcf8;border-radius:8px}.cluster-map rect{fill:#fbfcf8}.cluster-point{cursor:pointer;stroke:#fff;stroke-width:.22px;outline:none;transition:opacity .12s,r .12s,stroke-width .12s;fill:var(--cluster-color,#7f8d88)!important}.cluster-point.other-cluster{opacity:.18}.cluster-point.same-cluster{opacity:.86}.cluster-point:hover{opacity:1;stroke:#fff;stroke-width:.36px}.cluster-point.active{stroke:#fff;stroke-width:.42px;opacity:1}.cluster-map-label{z-index:1;border:1px solid #18201d14;border-left:4px solid var(--cluster-color,#7f8d88);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffeb;border-radius:8px;max-width:min(320px,100% - 28px);padding:10px 12px;position:absolute;top:14px;left:14px;box-shadow:0 14px 30px #1a1f281f}.cluster-map-label strong,.cluster-map-label span{display:block}.cluster-map-label strong{color:var(--ink)}.cluster-map-label span{color:var(--muted);margin-top:4px;font-size:12px;line-height:1.5}.cluster-list{align-content:start;gap:10px;display:grid}.cluster-card{border:1px solid var(--line);border-left:4px solid var(--cluster-color,#7f8d88);background:#fff;border-radius:8px;padding:12px}.cluster-card.active{border-color:color-mix(in srgb, var(--cluster-color,#7f8d88) 56%, var(--line));border-left-color:var(--cluster-color,#7f8d88);background:color-mix(in srgb, var(--cluster-color,#7f8d88) 10%, #fff)}.cluster-color-0{--cluster-color:#206758}.cluster-color-1{--cluster-color:#d36b28}.cluster-color-2{--cluster-color:#3b5f91}.cluster-color-3{--cluster-color:#b03a2e}.cluster-color-4{--cluster-color:#7a4bb0}.cluster-color-5{--cluster-color:#c59b18}.cluster-color-6{--cluster-color:#1f8a9a}.cluster-color-7{--cluster-color:#8d3f69}.cluster-card>div:first-child{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.cluster-card span,.cluster-card p,.cluster-card dt{color:var(--muted)}.cluster-card p{margin:8px 0 10px;font-size:13px;line-height:1.55}.cluster-card dl{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:0;display:grid}.cluster-card dt{font-size:12px}.cluster-card dd{margin:3px 0 0;font-weight:800}.side-stack{flex-direction:column;gap:16px;display:flex}.model-badge{min-height:34px;color:var(--accent-strong);white-space:nowrap;background:#eef5f1;border-radius:8px;align-items:center;gap:8px;padding:0 10px;font-size:13px;font-weight:700;display:inline-flex}.twin-workbench{border-bottom:1px solid var(--line);background:#f7f8f4;grid-template-columns:minmax(0,1fr) 280px;min-height:390px;display:grid}.bow-twin-canvas{min-height:390px}.bow-twin-canvas canvas{width:100%;height:100%;display:block}.draw-trajectory{background:#202622;width:100%;height:390px;padding:16px}.draw-trajectory rect{fill:#202622}.aim-ring{fill:none;stroke:#e1e6e247;stroke-width:1.4px}.trajectory-line{fill:none;stroke:#e3e2db38;stroke-width:1.5px}.trajectory-dot{fill:#dfdbd557;stroke:#ffb4be6b;stroke-width:1.2px}.trajectory-dot.active{fill:#f6bec7;stroke:#fff4f5;stroke-width:1.4px}.playback-controls{border-bottom:1px solid var(--line);grid-template-columns:auto minmax(0,1fr) 72px;align-items:center;gap:12px;padding:14px;display:grid}.playback-controls input,.range-input{min-height:42px;padding:0}.playback-controls strong{text-align:right}.feature-grid{border-bottom:1px solid var(--line);grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:14px;display:grid}.feature-tile{border:1px solid var(--line);background:#fbfcf8;border-radius:8px;min-height:68px;padding:12px}.feature-tile strong{color:var(--ink);margin-top:8px;font-size:20px;line-height:1;display:block}.attitude-chart-card{border:1px solid var(--line);background:#fbfcf8;border-radius:8px;margin:14px}.chart-legend{color:var(--muted);flex-wrap:wrap;gap:12px;padding:12px 14px 0;font-size:13px;font-weight:700;display:flex}.chart-legend span{align-items:center;gap:6px;display:inline-flex}.chart-legend span:before{content:"";background:currentColor;border-radius:999px;width:10px;height:10px}.legend-roll{color:#206758}.legend-pitch{color:#b03a2e}.legend-yaw{color:#3b5f91}.attitude-chart{width:100%;height:180px;padding:10px 14px 14px}.attitude-chart line{stroke:#d9dfd6}.attitude-chart polyline{fill:none;stroke-width:3px;stroke-linejoin:round;stroke-linecap:round}.roll-line{stroke:#206758}.pitch-line{stroke:#b03a2e}.yaw-line{stroke:#3b5f91}.shot-selector-body{gap:14px;padding:16px;display:grid}.shot-select{min-height:44px}.shot-meta{gap:10px;margin:0;display:grid}.shot-meta div{grid-template-columns:96px minmax(0,1fr);align-items:center;gap:10px;display:grid}.shot-meta dd{color:var(--ink);margin:0;font-weight:800}.compact-panel{padding:18px}.compact-panel h2{margin-bottom:14px}.compact-metric-list{gap:10px;display:grid}.mode-panel{border-bottom:1px solid var(--line);background:#f7f8f4;grid-template-columns:260px 180px minmax(180px,1fr);align-items:end;gap:14px;padding:18px 20px;display:grid}.segmented{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:1fr 1fr;gap:6px;padding:5px;display:grid}.segmented button{min-height:44px;color:var(--muted);background:0 0;border-radius:6px}.segmented button.active{color:#fff;background:var(--accent)}.fixed-input{color:var(--muted);gap:7px;font-size:13px;font-weight:700;display:grid}.nudge-grid{border-bottom:1px solid var(--line);grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:16px 20px;display:grid}.nudge-button{min-height:70px;color:var(--accent-strong);text-align:left;touch-action:none;-webkit-user-select:none;user-select:none;background:#eef5f1;border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:2px 8px;padding:12px;display:grid}.nudge-button span{color:var(--muted);grid-column:2;font-size:12px;font-weight:600}.nudge-button.primary,.nudge-button.primary span{color:#fff}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;padding:13px 14px}th{color:var(--muted);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;font-size:12px}td:last-child,th:last-child{text-align:center;width:72px}.icon-only{width:38px;height:38px;color:var(--danger);background:#b03a2e17;border-radius:8px;place-items:center;display:inline-grid}.message{min-height:20px;color:var(--muted);text-align:right}.message.ok{color:var(--ok)}.message.error{color:var(--danger)}@media (width<=1080px){.trend-grid,.cluster-layout,.analysis-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.analysis-grid .twin-panel{grid-column:1/-1}.analysis-grid .side-stack{grid-column:1/-1;grid-template-columns:repeat(2,minmax(0,1fr));display:grid}}@media (width<=760px){.app-frame{grid-template-columns:1fr}.app-sidebar{height:auto;padding:12px;position:static}.main-nav{grid-template-columns:1fr 1fr}.sidebar-stat{display:none}.content-shell{padding:16px}.page-header,.panel-head,.panel-footer{flex-direction:column;align-items:stretch}.toolbar{justify-content:stretch}.toolbar .icon-button{flex:120px}.trend-grid,.cluster-layout,.analysis-grid,.analysis-grid .side-stack,.mode-panel,.nudge-grid,.twin-workbench,.playback-controls{grid-template-columns:1fr}.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.bow-twin-canvas,.draw-trajectory{height:340px;min-height:340px}.playback-controls strong{text-align:left}}
