:root{--bg:#eef2f0;--panel:#fff;--panel-soft:#f7f9f8;--panel-raised:#fbfcfb;--line:#d5ddd9;--line-strong:#b9c6c1;--text:#1f2d2a;--muted:#60716c;--faint:#8b9a95;--blue:#287ea3;--blue-deep:#164252;--blue-soft:#dff0f6;--green:#0a7a6a;--green-soft:#dcefe7;--lime:#dff07c;--orange:#f47b20;--red:#d9514e;--shadow:0 14px 38px #1b2d2714;--smart-panel-width:264px;--inspector-width:360px;--font-ui:"Microsoft YaHei", "PingFang SC", "Noto Sans CJK SC", "Segoe UI", sans-serif;color:var(--text);font-family:var(--font-ui);font-synthesis:none;text-rendering:optimizelegibility}*{box-sizing:border-box}html,body,#app{height:100%;margin:0}body{background:var(--bg);min-width:1180px}button,input,select{font:inherit}button{cursor:pointer;border:0}button:focus-visible,input:focus-visible,select:focus-visible{outline-offset:2px;outline:2px solid #287ea373}.workspace-shell{grid-template-rows:auto minmax(0,1fr) 34px;height:100%;display:grid;overflow:hidden}.app-chrome{border-bottom:1px solid var(--line);color:#142421;background:#f7f8f7;flex-shrink:0}.window-row{align-items:center;gap:12px;height:32px;padding:0 14px;display:flex}.brand-mark{color:var(--green);background:#e6f0ed;border:1px solid #bcd0c8;place-items:center;width:20px;height:20px;display:grid}.brand-logo{color:var(--text);align-items:center;gap:10px;min-width:0;line-height:1;display:inline-flex}.brand-logo-mark{height:var(--brand-logo-size);width:var(--brand-logo-size);flex:none;display:block;overflow:visible}.brand-logo-sm{--brand-logo-size:28px;gap:8px}.brand-logo-md{--brand-logo-size:36px}.brand-logo-lg{--brand-logo-size:48px;gap:12px}.brand-logo-mark.brand-logo-sm,.brand-logo-mark.brand-logo-md,.brand-logo-mark.brand-logo-lg{gap:0}.brand-logo-text{gap:3px;min-width:0;display:grid}.brand-logo-text strong{color:var(--text);white-space:nowrap;font-size:15px;font-weight:800}.brand-logo-text small{color:var(--muted);white-space:nowrap;font-size:11px;font-weight:700}.brand-logo-lg .brand-logo-text strong{font-size:18px}.brand-logo-lg .brand-logo-text small{font-size:12px}.brand-logo-plate{fill:url(#qfy-logo-primary)}.brand-logo-signal,.brand-logo-cut,.brand-logo-pulse{fill:none;stroke:#fff;stroke-linecap:round;stroke-linejoin:round}.brand-logo-signal{stroke-width:3.8px}.brand-logo-cut,.brand-logo-pulse{opacity:.9;stroke-width:2.6px}.brand-logo-point{fill:#dff07c}.brand-logo-light,.brand-logo-light .brand-logo-text strong,.brand-logo-light .brand-logo-text small{color:#fff}.brand-logo-light .brand-logo-plate{fill:#fff}.brand-logo-light .brand-logo-signal,.brand-logo-light .brand-logo-cut,.brand-logo-light .brand-logo-pulse{stroke:var(--green)}.brand-logo-light .brand-logo-point{fill:var(--orange)}.brand-logo-mono .brand-logo-plate{fill:#2e3b38}.brand-logo-mono .brand-logo-point{fill:#fff}.window-title{white-space:nowrap;margin-right:10px;font-size:13px;font-weight:700}.menu-list{align-items:center;gap:1px;display:flex}.menu-list button{color:#0d1f1c;background:0 0;height:26px;padding:0 8px;font-size:13px}.menu-list button:hover,.text-tool:hover,.icon-button:hover{background:#e6ece9}.toolbar-row{background:#eef1ef;border-top:1px solid #fff;align-items:center;gap:10px;height:42px;padding:0 14px;display:flex}.tool-group{border-right:1px solid var(--line);align-items:center;gap:2px;padding-right:10px;display:flex}.icon-button{color:#56635f;background:0 0;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex}.icon-button svg{stroke-width:1.85px;flex:0 0 17px;width:17px;height:17px;display:block}.icon-button .lucide-arrow-left,.icon-button .lucide-arrow-right{width:18px;height:18px}.density-select{border:1px solid var(--line);color:#4c5b56;background:#fff;height:30px;padding:0 34px 0 12px}.toolbar-spacer{flex:1}.text-tool,.primary-tool,.show-me-trigger{align-items:center;gap:6px;height:30px;padding:0 10px;display:inline-flex}.text-tool svg,.primary-tool svg{stroke-width:1.9px;flex:0 0 16px;width:16px;height:16px;display:block}.show-me-trigger svg{stroke-width:1.9px;flex:0 0 17px;width:17px;height:17px;display:block}.text-tool{color:#53635e;background:0 0}.primary-tool{background:var(--green);color:#fff}.show-me-trigger{border-left:3px solid var(--blue);box-shadow:inset 0 0 0 1px var(--line);color:#17332e;background:#fff;font-weight:700}.workspace-body{grid-template-columns:258px minmax(620px, 1fr) var(--smart-panel-width);column-gap:0;min-height:0;display:grid;overflow:hidden}.workspace-body.has-inspector{grid-template-columns:258px minmax(620px, 1fr) var(--inspector-width) var(--smart-panel-width)}.field-sidebar,.smart-panel{background:var(--panel-raised);min-height:0;overflow:hidden}.field-sidebar{border-right:1px solid var(--line);grid-template-rows:auto auto auto minmax(0,1fr);display:grid}.sidebar-tabs{grid-template-columns:1fr 1fr;height:36px;display:grid}.sidebar-tabs button{border-bottom:1px solid var(--line);color:var(--muted);background:#f6f8f7}.sidebar-tabs .active{color:var(--text);background:#fff;border-bottom-color:#fff;font-weight:700}.data-source-card{border-bottom:1px solid var(--line);padding:12px 14px}.source-title{align-items:center;gap:7px;min-width:0;font-size:13px;font-weight:700;display:flex}.brand-mark svg,.source-title svg,.field-search svg,.field-group-title svg,.shelf-label svg,.smart-heading svg,.inspector-section h3 svg,.bottom-tabs svg{flex:none;display:block}.source-title svg,.field-search svg,.field-group-title svg,.shelf-label svg,.inspector-section h3 svg{stroke-width:1.9px;width:15px;height:15px}.source-title span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.source-meta{color:var(--muted);margin-top:5px;font-size:12px}.field-search{border:1px solid var(--line);background:#fff;align-items:center;gap:8px;height:32px;margin:10px 12px;padding:0 9px;display:flex}.field-search input{color:var(--text);border:0;outline:none;width:100%;min-width:0}.field-groups{padding:0 8px 14px;overflow:auto}.field-group+.field-group{margin-top:8px}.field-group-title{color:#243632;background:0 0;align-items:center;gap:4px;width:100%;height:28px;font-size:13px;font-weight:700;display:flex}.field-row{color:#263a35;text-align:left;background:0 0;grid-template-columns:16px minmax(0,1fr) 16px;align-items:center;gap:7px;width:100%;height:28px;padding:0 7px 0 18px;font-size:13px;display:grid}.field-row span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.field-row:hover,.field-row.used{background:#e8f2ef}.field-row svg{color:#2d8c74;stroke-width:1.9px;width:14px;height:14px;display:block}.field-row .lucide-variable{width:15px;height:15px}.field-row.warning .field-alert{color:var(--red);width:13px;height:13px}.workspace-main{background:#f8faf9;grid-template-rows:auto minmax(0,1fr);min-width:0;display:grid;overflow:hidden}.shelf-panel{border-bottom:1px solid var(--line);background:#fff;grid-template-columns:1fr;display:grid}.shelf-row{border-bottom:1px solid #edf1ef;grid-template-columns:120px minmax(0,1fr);align-items:center;min-height:36px;display:grid}.shelf-row:last-child{border-bottom:0}.shelf-row.filters{min-height:42px}.shelf-label{border-right:1px solid var(--line);color:#42534e;text-align:left;background:0 0;align-items:center;gap:7px;width:100%;height:100%;padding:0 12px;display:flex}.shelf-label:hover{color:var(--blue-deep);background:#eef6f3}.pill-track{flex-wrap:wrap;align-items:center;gap:6px;min-width:0;padding:5px 10px;display:flex}.field-pill{color:#fff;text-overflow:ellipsis;white-space:nowrap;background:#3f97b1;border-radius:999px;max-width:220px;height:24px;padding:0 12px;font-size:13px;overflow:hidden}.field-pill.green{background:#08a47b}.field-pill.orange{background:var(--orange)}.worksheet-canvas,.dashboard-canvas{min-width:0;padding:22px 24px 26px;overflow:auto}.canvas-header{justify-content:space-between;align-items:end;margin-bottom:18px;display:flex}.canvas-title-action{color:inherit;text-align:left;background:0 0;justify-items:start;min-width:0;max-width:820px;padding:0;display:grid}.canvas-title-action:hover .canvas-subtitle,.canvas-title-action:focus-visible .canvas-subtitle{color:#365a65}.canvas-title-action:hover h1,.canvas-title-action:focus-visible h1{color:var(--blue-deep)}.eyebrow{color:var(--green);letter-spacing:0;margin:0 0 4px;font-size:12px;font-weight:700}h1,h2,h3,p{margin-top:0}.canvas-header h1{margin:0 0 4px;font-size:24px;font-weight:600}.canvas-subtitle{color:var(--muted);max-width:760px;font-size:13px;line-height:1.5;display:block}.canvas-status{color:var(--muted);flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;font-size:12px;display:flex}.canvas-status span{border:1px solid var(--line);background:#fff;padding:4px 8px}.analysis-grid{grid-template-rows:minmax(350px,auto) minmax(250px,1fr);grid-template-columns:minmax(560px,1.55fr) minmax(320px,.8fr);gap:14px;display:grid}.worksheet-profile-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px;display:grid}.worksheet-profile-strip button{background:var(--panel);border:1px solid var(--line);text-align:left;gap:5px;min-height:64px;padding:10px 12px;display:grid;box-shadow:0 8px 22px #1b2d270d}.worksheet-profile-strip button:hover{background:var(--blue-soft);border-color:#b6d7e2}.worksheet-profile-strip span{color:var(--muted);font-size:12px}.worksheet-profile-strip strong{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.sheet-panel,.dashboard-widget{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow)}.panel-heading{border-bottom:1px solid #ebefed;justify-content:space-between;align-items:center;min-height:42px;padding:0 14px;display:flex}.panel-heading h2{margin:0;font-size:15px;font-weight:600}.panel-title-action{color:var(--text);text-align:left;background:0 0;min-width:0;margin:0;padding:0;font-size:15px;font-weight:600}.panel-title-action:hover,.panel-title-action:focus-visible{color:var(--blue-deep)}.panel-heading span{color:var(--muted);font-size:12px}.table-panel{overflow:hidden}.metric-table{border-collapse:collapse;width:100%;min-width:820px;font-size:13px}.metric-table th,.metric-table td{color:#485a54;text-align:right;white-space:nowrap;border-bottom:1px solid #edf1ef;padding:7px 10px}.metric-table th{color:#52645f;background:#fbfcfb;font-weight:600}.metric-table th button{color:inherit;font-weight:inherit;min-height:22px;text-align:inherit;background:0 0;padding:0}.metric-table th button:hover{color:var(--blue);text-underline-offset:3px;text-decoration:underline}.metric-table th:first-child,.metric-table th:nth-child(2),.metric-table td:first-child,.metric-table td:nth-child(2){text-align:left}.metric-table tbody tr:nth-child(2n){background:#f4f7f5}.metric-table td:nth-child(n+3),.metric-table tfoot td:nth-child(n+3){color:#58a05b}.metric-table .negative{color:var(--red)!important}.metric-table tfoot td{border-top:1px solid var(--line-strong);background:#fbfdfc;font-weight:700}.company-cell{border-right:1px solid var(--line);vertical-align:top;font-weight:600;color:#2f443f!important}.rank-panel{min-height:350px}.rank-list{gap:9px;padding:16px 14px;display:grid}.rank-row{grid-template-columns:minmax(92px,1fr) minmax(128px,1.4fr) 76px;align-items:center;gap:8px;display:grid}.rank-label,.rank-value{color:#52645f;text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.rank-value{text-align:right}.rank-bar-track{background:#edf2ef;height:18px}.rank-bar{background:linear-gradient(90deg,#e7f589,#00676b);height:100%}.trend-panel{min-width:0}.sparkline{height:250px;padding:18px 20px 22px}.sparkline svg{width:100%;height:100%;overflow:visible}.trend-area{fill:url(#trend-fill)}.trend-line{fill:none;stroke:#1b1f1d;stroke-linecap:round;stroke-linejoin:round;stroke-width:4px}.grid-lines line{stroke:#dce3df;stroke-dasharray:4 4}.composition-panel{min-height:250px}.donut-wrap{justify-content:center;align-items:center;gap:20px;min-height:196px;padding:18px;display:flex}.donut-chart{background:radial-gradient(circle closest-side, #fff 62%, transparent 64%), conic-gradient(var(--green) 0deg 136deg, var(--lime) 136deg 360deg);border-radius:50%;width:130px;height:130px}.donut-legend{gap:10px;display:grid}.donut-legend span{color:#4e625d;align-items:center;gap:8px;font-size:13px;display:flex}.donut-legend i{background:var(--lime);width:10px;height:10px;display:inline-block}.donut-legend i.dark{background:var(--green)}.smart-panel{border-left:1px solid var(--line);padding:14px;overflow:auto}.smart-heading{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.smart-heading h2{margin:0;font-size:16px}.smart-heading-action{text-align:left;background:0 0;border:0;gap:2px;min-width:0;padding:0;display:grid}.smart-heading-action:hover h2,.smart-heading-action:focus-visible h2{color:var(--blue-deep)}.smart-heading svg{stroke-width:1.85px;width:18px;height:18px}.chart-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.chart-tile{border:1px solid var(--line);color:#445751;background:#fff;place-items:center;gap:5px;min-height:72px;padding:7px 4px;font-size:11px;display:grid;position:relative}.chart-tile.active{border-color:var(--blue);color:#133e4d;box-shadow:inset 0 0 0 2px #287ea329}.chart-tile.disabled{color:#a6b2ae;cursor:not-allowed;opacity:.55}.chart-tile>svg{color:var(--green);stroke-width:2px;width:13px;height:13px;display:block;position:absolute;top:5px;right:5px}.chart-tile>.lucide-check{width:14px;height:14px}.chart-type-icon{width:45px;height:34px;line-height:0;display:block}.chart-type-icon svg{width:45px;height:34px;display:block;overflow:visible}.chart-icon-panel{fill:#f8fbfb;stroke:#c9d8d3;stroke-width:1px}.chart-icon-grid,.chart-icon-axis{fill:none;stroke:#b8cac4;stroke-linecap:round;stroke-width:1px}.chart-icon-line{fill:none;stroke:#f2a24a;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.4px}.chart-icon-point,.chart-icon-mark{fill:var(--green)}.chart-icon-mark.chart-icon-warm,.chart-icon-warm{fill:#f2a24a}.chart-icon-blue{fill:#8dbbd6}.chart-icon-green{fill:#77bea6}.chart-icon-cell,.chart-icon-accent-soft{opacity:.95}.chart-icon-accent-soft,.chart-icon-area{fill:#77bea647}.chart-icon-ring{fill:none;stroke:#8dbbd6;stroke-width:1px}.chart-icon-map-a{fill:#dff0f6;stroke:#8dbbd6;stroke-linejoin:round;stroke-width:1px}.chart-icon-map-b{fill:#e8f2ef;stroke:#77bea6;stroke-linejoin:round;stroke-width:1px}.chart-icon-map-c{fill:#fff1de;stroke:#f2a24a;stroke-linejoin:round;stroke-width:1px}.chart-icon-pin{fill:var(--green);stroke:#fff;stroke-width:1px}.inspector-section{border-top:1px solid var(--line);margin-top:16px;padding-top:14px}.inspector-section h3{color:#2c3d39;align-items:center;gap:7px;margin-bottom:10px;font-size:14px;font-weight:700;display:flex}.inspector-section-title{color:#2c3d39;text-align:left;background:0 0;border:0;align-items:center;gap:7px;margin-bottom:10px;padding:0;font-size:14px;font-weight:700;display:flex}.inspector-section-title:hover,.inspector-section-title:focus-visible{color:var(--blue-deep)}.mark-type{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}.mark-type button,.dashboard-presets button{border:1px solid var(--line);color:#455954;background:#fff;min-height:30px}.mark-type .selected{background:var(--green);border-color:var(--green);color:#fff}.encoding-list{gap:7px;margin-top:12px;display:grid}.encoding-pill{border-left:3px solid var(--green);background:#eaf4f1;justify-content:space-between;min-width:0;padding:7px 9px;display:flex}.encoding-pill span{color:#263b36;text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.encoding-pill small{color:var(--muted);margin-left:8px}.dashboard-presets{gap:7px;display:grid}.dashboard-toolbar{border:1px solid var(--line);background:#fff;grid-template-columns:1fr 1fr auto;align-items:center;gap:12px;margin-bottom:14px;padding:10px 14px;display:grid}.dashboard-profile-strip{grid-template-columns:100px minmax(160px,1fr) repeat(4,minmax(130px,.75fr));gap:10px;margin-bottom:14px;display:grid}.dashboard-profile-strip button{border:1px solid var(--line);color:var(--text);text-align:left;background:#fff;gap:4px;min-width:0;min-height:58px;padding:9px 10px;display:grid;box-shadow:0 8px 22px #1b2d270d}.dashboard-profile-strip button:hover{background:var(--blue-soft);border-color:#b6d7e2}.dashboard-profile-strip strong,.dashboard-profile-strip span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.dashboard-profile-strip strong{font-size:13px}.dashboard-profile-strip span{color:var(--muted);font-size:12px}.dashboard-toolbar label{color:#4e625d;grid-template-columns:78px minmax(0,1fr);align-items:center;gap:8px;display:grid}.dashboard-filter-label{color:#4e625d;font:inherit;text-align:left;text-overflow:ellipsis;white-space:nowrap;background:0 0;min-width:0;padding:0;overflow:hidden}.dashboard-filter-label:hover,.dashboard-filter-label:focus-visible{color:var(--blue-deep)}.dashboard-toolbar select{border:1px solid var(--line);height:28px;padding:0 8px}.dashboard-toolbar span{color:var(--muted);font-size:13px}.dashboard-toolbar strong{color:var(--red);font-weight:500}.dashboard-grid{grid-template-rows:240px 260px;grid-template-columns:repeat(4,minmax(170px,1fr));gap:14px;display:grid}.dashboard-widget{min-width:0;padding:16px;overflow:hidden}.dashboard-widget.kpi{background:var(--orange);color:#fff;grid-column:span 1}.dashboard-widget.donut,.dashboard-widget.bar{grid-column:span 1}.dashboard-widget.pareto,.dashboard-widget.line,.dashboard-widget.bar:last-child{grid-column:span 2}.widget-title{margin-bottom:14px;font-size:17px}.widget-insight{color:var(--muted);margin-top:12px;font-size:12px;line-height:1.45;display:block}.dashboard-widget.kpi .widget-insight{color:#ffffffd1}.kpi-block{place-items:center;height:160px;display:grid}.kpi-block span{font-size:16px}.kpi-block strong{font-size:30px}.dashboard-donut{min-height:150px;padding:4px}.dashboard-bars{gap:12px;margin-top:22px;display:grid}.dashboard-bars div{background:#eef2ef;height:16px}.dashboard-line{border-bottom:1px solid var(--line);align-items:end;gap:7px;height:180px;padding:20px 0 0;display:flex}.dashboard-line span{background:#d2d7d5;flex:1}.dashboard-line span:first-child{background:#59bd91}.bottom-tabs{border-top:1px solid var(--line-strong);background:#e5ebe8;align-items:stretch;min-width:0;display:flex;overflow-x:auto}.bottom-tabs button{border-right:1px solid var(--line);color:#3d4d49;background:0 0;flex:none;align-items:center;gap:5px;min-width:86px;max-width:170px;padding:0 10px;font-size:12px;display:inline-flex}.bottom-tabs svg{stroke-width:1.9px;width:14px;height:14px}.bottom-tabs button.active{border-top:3px solid var(--blue);color:#132f39;background:#fff;font-weight:700}.bottom-tabs span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.brand-logo-spec{grid-template-columns:minmax(520px,1.2fr) minmax(360px,.8fr);gap:18px;display:grid}.brand-logo-hero{grid-column:1/-1;grid-template-columns:minmax(0,1fr) 320px;align-items:center;gap:28px;min-height:240px;display:grid}.brand-logo-hero p:not(.spec-kicker){color:var(--muted);max-width:620px;margin:0;line-height:1.75}.brand-logo-hero-mark{border:1px solid var(--line);background:linear-gradient(135deg,#dff0f6eb,#dcefe7b8),#fff;place-items:center;min-height:170px;display:grid}.logo-variant-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.logo-variant-grid>div,.logo-scale-list>div{border:1px solid var(--line);background:#f7faf8;align-items:center;gap:12px;min-height:78px;padding:14px;display:flex}.logo-variant-grid span,.logo-scale-list span{color:var(--muted);font-size:12px;font-weight:700}.logo-dark-sample{background:#113431!important;border-color:#113431!important}.logo-dark-sample span{color:#fff}.logo-scale-list{gap:10px;display:grid}.design-spec-grid{grid-template-columns:minmax(520px,1.1fr) minmax(420px,.85fr);gap:18px;display:grid}.web-type-list{display:grid}.web-type-row{border-bottom:1px solid #e5ece8;grid-template-columns:130px minmax(0,1fr) 170px;gap:8px;padding:14px 0;display:grid}.web-type-row:last-child{border-bottom:0}.web-type-row span,.web-type-row small{color:var(--muted);font-size:12px;line-height:1.4}.web-type-row small{justify-self:end}.web-type-row strong{color:var(--text);text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.web-type-display strong{font-variant-numeric:tabular-nums;font-size:30px;font-weight:700;line-height:1.1}.web-type-title strong{font-size:24px;font-weight:600;line-height:1.25}.web-type-panel strong{font-size:16px;font-weight:600}.web-type-body strong{font-size:13px;font-weight:500}.web-type-caption strong{color:var(--muted);font-size:12px;font-weight:500}.font-stack-sample{background:var(--panel-soft);border:1px solid var(--line);color:var(--text);margin-bottom:14px;padding:12px 14px;font-size:13px;font-weight:700}.web-color-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.web-color-chip{background:var(--panel-soft);border:1px solid var(--line);align-items:center;gap:10px;min-width:0;min-height:58px;padding:10px;display:flex}.web-color-chip i{border:1px solid #00000014;flex:0 0 38px;width:38px;height:30px;display:block}.web-color-chip div{gap:4px;min-width:0;display:grid}.web-color-chip strong{color:var(--text);font-size:13px}.web-color-chip span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.web-surface-demo{gap:10px;margin-bottom:16px;display:grid}.web-surface-demo div{border:1px solid var(--line);color:var(--text);min-height:48px;padding:15px;font-size:13px;font-weight:700}.surface-bg{background:var(--bg)}.surface-panel{background:var(--panel);box-shadow:var(--shadow)}.surface-active{background:var(--green);border-color:var(--green)!important;color:#fff!important}.web-spacing-list{gap:10px;display:grid}.web-spacing-row{grid-template-columns:52px minmax(20px,140px) minmax(0,1fr);align-items:center;gap:12px;display:grid}.web-spacing-row span,.web-spacing-row strong{color:var(--muted);font-size:12px}.web-spacing-row strong{color:var(--text);font-weight:700}.web-spacing-row i{background:linear-gradient(90deg, var(--blue-soft), var(--blue));height:16px;display:block}.web-size-grid{gap:12px;display:grid}.web-size-grid div{color:var(--muted);border-bottom:1px solid #e5ece8;grid-template-columns:78px 190px minmax(0,1fr);align-items:center;gap:12px;min-height:48px;font-size:12px;display:grid}.web-size-grid div:last-child{border-bottom:0}.web-size-grid span{color:var(--text);font-weight:700}.web-size-grid i{background:var(--green-soft);border:1px solid #b9d1ca;display:block}.web-radius-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.web-radius-list div{color:var(--muted);align-items:center;gap:8px;font-size:12px;display:grid}.web-radius-list i{background:var(--blue-soft);border:1px solid #b8d4df;width:100%;height:38px;display:block}@media (width<=1540px){:root{--smart-panel-width:220px;--inspector-width:300px}.workspace-body{grid-template-columns:220px minmax(520px, 1fr) var(--smart-panel-width)}.workspace-body.has-inspector{grid-template-columns:220px minmax(520px, 1fr) var(--inspector-width) var(--smart-panel-width)}.analysis-grid{grid-template-columns:1fr}.rank-panel,.composition-panel{min-height:240px}.dashboard-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}.brand-logo-spec,.brand-logo-hero,.design-spec-grid{grid-template-columns:1fr}}.brand-mark,.window-title{border:0}.window-title{color:inherit;text-align:left;background:0 0;padding:0}.menu-item{position:relative}.menu-list button.active{color:#0d332d;background:#dfe9e5}.menu-popover{border:1px solid var(--line-strong);z-index:30;background:#fff;gap:2px;min-width:250px;padding:6px;display:grid;position:absolute;top:28px;left:0;box-shadow:0 18px 34px #1829252e}.menu-action{color:var(--text);text-align:left;background:0 0;justify-content:space-between;align-items:center;gap:16px;min-height:46px;padding:7px 9px;display:flex}.menu-action:hover,.menu-action.primary:hover{background:var(--blue-soft)}.menu-action.disabled{color:var(--faint)}.menu-action.primary strong{color:var(--blue)}.menu-action span{gap:3px;min-width:0;display:grid}.menu-action strong,.menu-action small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.menu-action strong{font-size:13px;font-weight:700}.menu-action small{color:var(--muted);font-size:12px}.menu-action kbd{border:1px solid var(--line);color:var(--muted);background:#eef4f2;padding:2px 5px;font-size:11px}.menu-pop-enter-active,.menu-pop-leave-active{transform-origin:0 0;transition:opacity .14s,transform .14s}.menu-pop-enter-from,.menu-pop-leave-to{opacity:0;transform:translateY(-4px)scale(.98)}.base-modal-layer{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;background:radial-gradient(circle at 50% 36%,#ffffff2e,#0000 32%),#131f2470;justify-content:center;align-items:center;padding:32px;display:flex;position:fixed;inset:0}.base-modal-panel{color:var(--text);scrollbar-color:#b8c9c4 transparent;scrollbar-width:thin;background:#fff;border:1px solid #596f7a57;border-radius:8px;max-height:min(720px,100vh - 64px);overflow:auto;box-shadow:0 30px 76px #0d1c2252}.review-modal{gap:16px;width:min(760px,100vw - 48px);max-width:760px;padding:24px;display:grid}.review-modal-head{justify-content:space-between;align-items:flex-start;gap:18px;display:flex}.review-modal-head div{gap:8px;min-width:0;display:grid}.review-modal-head span{color:var(--blue-deep);background:linear-gradient(135deg,#dceff6,#edf7f5);border-radius:999px;justify-content:center;align-items:center;width:38px;height:22px;font-size:11px;font-weight:800;display:inline-flex}.review-modal-head h2{margin:0;font-size:20px;line-height:1.2}.review-modal-head p{color:var(--muted);margin:0;line-height:1.7}.review-modal-head button{border:1px solid var(--line);color:var(--muted);background:#f3f7f8;border-radius:6px;justify-content:center;align-items:center;min-width:32px;height:32px;display:inline-flex}.review-modal-head button:hover{background:var(--blue-soft);color:var(--blue-deep)}.review-modal-detail{border:1px solid var(--line);border-radius:7px;gap:0;margin:0;display:grid;overflow:hidden}.review-modal-detail div{border-bottom:1px solid var(--line);grid-template-columns:92px 1fr;gap:6px;padding:11px 12px;display:grid}.review-modal-detail div:last-child{border-bottom:0}.review-modal-detail dt{color:var(--faint);font-size:12px}.review-modal-detail dd{color:var(--text);margin:0;line-height:1.6}.review-modal-steps{gap:10px;display:grid}.review-modal-steps h3{margin:0;font-size:13px}.review-modal-steps ol{gap:8px;margin:0;padding-left:20px;display:grid}.review-modal-steps li{color:var(--muted);line-height:1.6}.review-modal-actions{flex-wrap:wrap;gap:10px;display:flex}.review-modal-actions button{color:var(--blue-deep);background:linear-gradient(135deg,#dff0f6,#eaf4f1);border-radius:6px;align-items:center;gap:7px;min-height:34px;padding:0 12px;font-weight:700;display:inline-flex}.review-modal-actions button:hover{background:#d9ecf8}.review-modal-foot{border-top:1px solid var(--line);color:var(--faint);padding-top:12px;font-size:12px;line-height:1.6}.review-modal-foot span{align-items:center;gap:6px;display:inline-flex}.base-modal-enter-active,.base-modal-leave-active{transition:-webkit-backdrop-filter .2s,backdrop-filter .2s,opacity .2s}.base-modal-enter-active .base-modal-panel,.base-modal-leave-active .base-modal-panel{transition:opacity .21s,transform .21s cubic-bezier(.2,.9,.2,1)}.base-modal-enter-from,.base-modal-leave-to{-webkit-backdrop-filter:blur();backdrop-filter:blur();opacity:0}.base-modal-enter-from .base-modal-panel,.base-modal-leave-to .base-modal-panel{opacity:0;transform:translateY(18px)scale(.97)}@media (width<=720px){.base-modal-layer{padding:14px}.base-modal-panel{max-height:calc(100vh - 28px)}.review-modal{width:100%;padding:18px}.review-modal-head{gap:12px}.review-modal-detail div{grid-template-columns:1fr}}.highlighted{box-shadow:inset 0 0 0 2px #287ea333}.data-source-card{text-align:left;background:0 0;width:100%}.sidebar-tabs button{transition:background .16s,color .16s}.field-group-title{justify-content:start}.field-group-title small{color:var(--faint);margin-left:auto;padding-right:4px;font-size:11px}.field-group-title svg{transition:transform .16s}.field-group-title svg.collapsed{transform:rotate(-90deg)}.field-row-wrap{grid-template-columns:minmax(0,1fr) auto;align-items:center;display:grid}.field-row-wrap.selected{background:#dff0f6}.field-row-wrap:hover .field-row-actions,.field-row-wrap:focus-within .field-row-actions,.field-row-wrap.selected .field-row-actions{opacity:1}.field-row-actions{opacity:.58;align-items:center;padding-right:4px;transition:opacity .12s;display:inline-flex}.field-row-actions button{color:var(--muted);background:0 0;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.field-row-actions button:hover{color:var(--blue);background:#dcebe6}.analysis-sidebar{gap:12px;padding:0 10px 16px;display:grid;overflow:auto}.analysis-sidebar section{border-top:1px solid var(--line);padding-top:10px}.analysis-sidebar button{color:#2a3c37;text-align:left;background:0 0;grid-template-columns:16px minmax(0,1fr);align-items:center;gap:7px;width:100%;min-height:31px;padding:5px 7px;font-size:12px;display:grid}.analysis-sidebar .analysis-section-title{color:var(--muted);width:auto;min-height:22px;margin:0 0 8px;padding:0 2px;font-size:12px;font-weight:700;display:inline-flex}.analysis-sidebar .analysis-section-title:hover,.analysis-sidebar .analysis-section-title:focus-visible{color:var(--blue-deep);background:0 0}.analysis-sidebar button.active,.analysis-sidebar button:hover{background:#e8f2ef}.analysis-sidebar button span,.analysis-sidebar button small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.analysis-sidebar button small{color:var(--faint);grid-column:2}.field-pill-wrap{align-items:center;min-width:0;max-width:290px;display:inline-flex}.field-pill.active{box-shadow:inset 0 0 0 2px #ffffff8c,0 0 0 2px #287ea32e}.pill-remove{color:#4559548a;opacity:0;pointer-events:none;background:0 0;border-radius:999px;justify-content:center;align-items:center;width:18px;min-width:18px;height:18px;margin-left:-7px;transition:opacity .12s,background-color .12s,color .12s,transform .12s;display:inline-flex;transform:scale(.9)}.field-pill-wrap:hover .pill-remove,.field-pill-wrap:focus-within .pill-remove,.pill-remove:focus-visible{opacity:1;pointer-events:auto;transform:scale(1)}.pill-remove:hover{color:var(--red);background:#f8e7e4}.pill-remove:focus-visible{outline:none;box-shadow:0 0 0 2px #287ea338}.pill-value{border:1px solid var(--line);color:var(--muted);background:#fff;max-width:86px;height:24px;margin-left:4px;padding:0 4px}.drop-hint{color:var(--faint);font-size:12px}.canvas-status button,.panel-heading button{border:1px solid var(--line);color:var(--muted);background:#fff;align-items:center;gap:5px;min-height:25px;padding:4px 8px;font-size:12px;display:inline-flex}.panel-heading button{background:0 0;border-color:#0000}.canvas-status button:hover,.panel-heading button:hover{background:var(--blue-soft);color:#173f4f}.metric-table tbody tr,.metric-table tfoot tr{cursor:pointer}.metric-table tbody tr:hover,.metric-table tbody tr.selected{background:#e3f2ee}.rank-row{text-align:left;background:0 0;border:0;width:100%;min-width:0;padding:0}.rank-row:hover .rank-label,.rank-row.selected .rank-label{color:var(--blue);font-weight:700}.rank-row.selected .rank-bar{background:linear-gradient(90deg, #9fd7ea, var(--blue))}.sparkline,.donut-wrap{color:inherit;text-align:left;background:0 0;border:0;width:100%}.sparkline:hover .trend-line{stroke:var(--blue)}.donut-wrap{cursor:pointer}.interaction-console{grid-template-columns:minmax(300px,1.1fr) minmax(260px,.75fr) minmax(300px,.9fr);gap:14px;margin-top:14px;display:grid}.review-grid{grid-template-columns:minmax(420px,.9fr) minmax(520px,1.1fr);gap:14px;margin-top:14px;display:grid}.review-panel{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);min-width:0}.asset-list,.capability-bars{gap:8px;padding:12px;display:grid}.asset-list button,.capability-bars button{border:1px solid var(--line);color:var(--text);text-align:left;background:#f8fbfa;gap:7px;min-width:0;min-height:54px;padding:9px 10px;display:grid;position:relative}.asset-list button{grid-template-columns:minmax(0,1fr) auto;align-items:center}.asset-list button:hover,.asset-list button.active,.capability-bars button:hover,.capability-bars button.active{background:var(--blue-soft);border-color:#b6d7e2}.asset-list span,.asset-list strong,.asset-list small,.capability-bars span,.capability-bars strong,.capability-bars small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.asset-list strong,.capability-bars strong{font-size:13px;display:block}.asset-list small,.capability-bars small{color:var(--muted);margin-top:4px;font-size:12px;display:block}.asset-list i,.capability-bars i{color:var(--blue);background:#eef4f2;padding:3px 6px;font-size:11px;font-style:normal;font-weight:700}.capability-bars button{padding-bottom:18px}.capability-bars em{background:linear-gradient(90deg, #9fcfdc, var(--blue));max-width:calc(100% - 58px);height:4px;display:block;position:absolute;bottom:7px;left:10px}.capability-bars i{position:absolute;top:9px;right:10px}.console-card{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);gap:8px;min-height:128px;padding:14px;display:grid}.console-card.primary{grid-template-columns:minmax(0,1fr) auto;align-items:center}.selection-summary-action{text-align:left;background:0 0;border:0;gap:0;min-width:0;padding:0;display:grid}.selection-summary-action:hover h2,.selection-summary-action:focus-visible h2{color:var(--blue-deep)}.console-card p{color:var(--green);margin-bottom:4px;font-size:12px;font-weight:700}.console-card h2,.console-card h3{align-items:center;gap:7px;margin:0;display:flex}.console-title-action{color:var(--text);text-align:left;background:0 0;justify-content:start;align-items:center;gap:7px;margin:0;padding:0;font-size:14px;font-weight:700;display:flex}.console-title-action:hover,.console-title-action:focus-visible{color:var(--blue-deep)}.console-card h2{font-size:18px}.console-card h3{font-size:14px}.console-card span{color:var(--muted);font-size:12px}.console-card button{border:1px solid var(--line);color:#2d433d;text-align:left;background:#f7faf8;justify-content:space-between;align-items:center;gap:8px;min-height:30px;padding:6px 8px;display:flex}.console-card button:hover,.console-card button.active{background:var(--blue-soft);border-color:#b7d7e3}.console-card strong{color:var(--text);font-size:12px}.smart-icon-button{color:var(--green);background:0 0;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex}.encoding-pill{border:0;width:100%}.parameter-list{gap:8px;display:grid}.parameter-list label{grid-template-columns:minmax(80px,1fr) minmax(80px,1fr);align-items:center;gap:7px;display:grid}.parameter-name-button{color:var(--muted);font:inherit;text-align:left;text-overflow:ellipsis;white-space:nowrap;background:0 0;min-width:0;padding:0;font-size:12px;overflow:hidden}.parameter-name-button:hover,.parameter-name-button:focus-visible{color:var(--blue-deep)}.parameter-list select,.parameter-list input{border:1px solid var(--line);color:#2d403b;background:#fff;min-width:0;height:28px;padding:0 7px}.data-source-canvas{min-width:0;padding:22px 24px 26px;overflow:auto}.source-layout{grid-template-columns:minmax(320px,.45fr) minmax(560px,1fr);gap:14px;display:grid}.source-list{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);gap:8px;padding:12px;display:grid}.source-list button{border:1px solid var(--line);color:var(--text);text-align:left;background:#f8fbfa;grid-template-columns:24px minmax(0,1fr) auto;align-items:center;gap:10px;min-height:62px;padding:10px;display:grid}.source-list button.active,.source-list button:hover{background:var(--blue-soft);border-color:#b6d7e2}.source-list span,.source-list strong,.source-list small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.source-list strong{font-size:13px;display:block}.source-list small{color:var(--muted);margin-top:4px;font-size:12px;display:block}.source-list i{color:var(--muted);background:#edf3f0;padding:3px 6px;font-size:11px;font-style:normal}.source-detail{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);padding:18px}.source-detail-head{color:inherit;text-align:left;background:0 0;grid-template-columns:34px minmax(0,1fr);align-items:start;gap:14px;width:100%;padding:0;display:grid}.source-detail-head:hover h2,.source-detail-head:focus-visible h2{color:var(--blue-deep)}.source-detail-head h2{margin-bottom:7px;font-size:20px}.source-detail-head p{color:var(--muted);margin:0;line-height:1.6}.source-metrics{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:18px 0;display:grid}.source-metrics button{border:1px solid var(--line);text-align:left;background:#f7faf8;gap:6px;min-height:76px;padding:12px;display:grid}.source-metrics button:hover{background:var(--blue-soft)}.source-metrics span{color:var(--muted);font-size:12px}.source-metrics strong{color:var(--text);font-size:16px}.source-preview-table{border:1px solid var(--line);display:grid}.source-preview-row{color:var(--text);text-align:left;background:#fff;border-bottom:1px solid #edf1ef;grid-template-columns:minmax(180px,1fr) 90px 90px 90px;gap:10px;min-height:36px;padding:0 12px;font-size:13px;display:grid}.source-preview-row.header{color:var(--muted);background:#f8faf9;align-items:center;font-weight:700}.source-preview-row.header button{color:inherit;text-align:left;background:0 0;min-height:28px;padding:0;font-weight:700}.source-preview-row.header button:hover,.source-preview-row.header button.active{color:var(--blue)}button.source-preview-row{align-items:center}button.source-preview-row:hover{background:#e8f2ef}.source-review-grid{grid-template-columns:minmax(420px,1fr) minmax(420px,1fr);gap:14px;margin-top:14px;display:grid}.source-review-grid article{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);min-width:0}.source-review-list,.import-flow{gap:8px;padding:12px;display:grid}.source-review-list button,.import-flow button{border:1px solid var(--line);color:var(--text);text-align:left;background:#f8fbfa;gap:5px;min-height:54px;padding:10px;display:grid}.source-review-list button{grid-template-columns:minmax(0,1fr) auto;align-items:center}.source-review-list button:hover,.source-review-list button.active,.import-flow button:hover{background:var(--blue-soft);border-color:#b6d7e2}.source-review-list strong,.source-review-list small,.import-flow strong,.import-flow span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.source-review-list strong,.import-flow strong{font-size:13px}.source-review-list small,.import-flow span{color:var(--muted);font-size:12px}.source-review-list i{color:var(--blue);background:#eef4f2;padding:3px 6px;font-size:11px;font-style:normal;font-weight:700}.dashboard-widget{text-align:left;transition:border-color .16s,box-shadow .16s,transform .16s}.dashboard-widget:hover,.dashboard-widget.selected{border-color:var(--blue);box-shadow:0 16px 36px #287ea329}.dashboard-widget.selected{transform:translateY(-1px)}.widget-title{justify-content:space-between;align-items:center;display:flex}.dashboard-bars span{background:#eef2ef;height:16px;display:block}.dashboard-bars i{background:linear-gradient(90deg, #f3695f, var(--orange));height:100%;display:block}.dashboard-action-strip{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;justify-content:space-between;align-items:center;gap:16px;min-height:48px;margin-top:14px;padding:10px 14px;display:flex}.dashboard-selection-action{color:var(--muted);text-align:left;background:0 0;border:0;align-items:center;gap:8px;min-width:0;padding:0;display:flex}.dashboard-selection-action:hover,.dashboard-selection-action:focus-visible{color:var(--blue-deep)}.dashboard-action-strip span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dashboard-action-strip button{background:var(--blue-soft);color:#164252;min-height:30px;padding:0 10px}.dashboard-rule-grid{grid-template-columns:repeat(4,minmax(180px,1fr));gap:10px;margin-top:14px;display:grid}.dashboard-rule-grid button{border:1px solid var(--line);color:var(--text);text-align:left;background:#fff;gap:5px;min-height:82px;padding:11px 12px;display:grid;box-shadow:0 8px 22px #1b2d270d}.dashboard-rule-grid button:hover,.dashboard-rule-grid button.active{background:var(--blue-soft);border-color:#b6d7e2}.dashboard-rule-grid strong,.dashboard-rule-grid span,.dashboard-rule-grid small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.dashboard-rule-grid strong{font-size:13px}.dashboard-rule-grid span,.dashboard-rule-grid small{color:var(--muted);font-size:12px}.interaction-inspector{border-left:1px solid var(--line-strong);border-right:1px solid var(--line);z-index:25;background:#fff;width:100%;min-height:0;padding:14px;display:block;position:relative;overflow:auto;box-shadow:-10px 0 22px #18292514}.inspector-slide-enter-active,.inspector-slide-leave-active{transition:opacity .18s,transform .18s}.inspector-slide-enter-from,.inspector-slide-leave-to{opacity:0;transform:translate(-12px)}.inspector-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:start;margin-bottom:14px;padding-bottom:12px;display:flex}.inspector-head p{color:var(--green);margin-bottom:4px;font-size:12px;font-weight:700}.inspector-head h2{margin:0;font-size:18px}.inspector-head button{color:var(--muted);background:#eef3f1;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.inspector-body{gap:12px;display:grid}.detail-block{border:1px solid var(--line);background:#f7faf8;gap:7px;padding:12px;display:grid}.detail-block strong{align-items:center;gap:7px;display:flex}.detail-block span{color:var(--muted);font-size:13px;line-height:1.6}.action-row{flex-wrap:wrap;gap:8px;display:flex}.action-row button{background:var(--blue-soft);color:#164252;min-height:30px;padding:0 10px}.inspector-control{color:var(--muted);gap:7px;font-size:12px;display:grid}.inspector-control select,.inspector-control input,.filter-list select{border:1px solid var(--line);color:var(--text);background:#fff;height:32px;padding:0 8px}.interaction-inspector code{color:#d9f1ea;white-space:pre-wrap;background:#172622;padding:10px;font-family:Cascadia Code,Consolas,monospace;font-size:12px;line-height:1.6;display:block;overflow:auto}.calculation-detail{gap:8px;margin:0;display:grid}.calculation-detail div{border:1px solid var(--line);background:#f8faf9;gap:5px;padding:9px 10px;display:grid}.calculation-detail dt{color:var(--muted);font-size:12px}.calculation-detail dd{color:var(--text);margin:0;font-size:13px;line-height:1.5}.filter-list{gap:8px;display:grid}.filter-list label{grid-template-columns:minmax(100px,1fr) minmax(100px,1fr);align-items:center;gap:8px;display:grid}.filter-list span{color:var(--muted);font-size:12px}.action-list{color:var(--muted);gap:8px;margin:0;padding-left:18px;font-size:13px;line-height:1.5;display:grid}.context-review-note{background:#f4f8fb;border:1px solid #c7dce6;gap:10px;margin-top:12px;padding:12px;display:grid}.context-review-head{align-items:center;gap:8px;display:flex}.context-review-head span{color:#174354;background:#d8ecf6;padding:3px 6px;font-size:11px;font-weight:800}.context-review-head strong{color:var(--text);font-size:14px}.context-review-note p{color:var(--muted);margin:0;font-size:13px;line-height:1.6}.button-list{gap:8px;display:grid}.button-list button{border:1px solid var(--line);color:var(--text);text-align:left;background:#f8faf9;gap:4px;min-height:48px;padding:8px 10px;display:grid}.button-list button:hover,.button-list button.active{background:var(--blue-soft);border-color:#b6d7e2}.button-list span,.button-list small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.button-list span{font-size:13px;font-weight:700}.button-list small{color:var(--muted);font-size:12px}.worksheet-chip-list{flex-wrap:wrap;gap:7px;display:flex}.worksheet-chip-list button{color:#36524b;text-overflow:ellipsis;white-space:nowrap;background:#eef4f2;max-width:100%;min-height:26px;padding:0 8px;font-size:12px;overflow:hidden}.worksheet-chip-list button:hover{background:var(--blue-soft);color:#174354}.operation-log{border-top:1px solid var(--line);gap:8px;margin-top:14px;padding-top:12px;display:grid}.operation-log h3{margin:0;font-size:13px}.log-item{border:0;border-left:3px solid var(--line-strong);text-align:left;background:#f8faf9;gap:3px;padding:8px 9px;transition:background .14s,border-color .14s,transform .14s;display:grid}.log-item:hover{border-left-color:var(--blue);background:#eef6f3;transform:translate(1px)}.log-item.success{border-left-color:var(--green)}.log-item.warning{border-left-color:var(--orange)}.log-item span{color:var(--faint);font-size:11px}.log-item strong{color:var(--text);font-size:12px}.log-item small{color:var(--muted);font-size:12px;line-height:1.5}@media (width<=1400px){.interaction-console,.review-grid,.source-review-grid,.source-layout{grid-template-columns:1fr}.worksheet-profile-strip,.dashboard-profile-strip,.dashboard-rule-grid,.source-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}:root{--preview-bg:#e8edf3;--preview-panel:#fff;--preview-line:#d4dde9;--preview-text:#101c2c;--preview-muted:#66768a;--preview-accent:#006dff;--preview-accent-2:#2f86ff;--preview-ink:#07152b;--preview-accent-soft:#e7f1ff;--preview-success:#27a66f;--preview-warning:#f2a93b;--preview-danger:#d94b4b;--preview-radius-sm:6px;--preview-radius-md:12px;--preview-radius-lg:14px;--preview-focus:0 0 0 3px #006dff38}html{scrollbar-width:none}html::-webkit-scrollbar{display:none}body::-webkit-scrollbar{display:none}body{background:var(--preview-bg);scrollbar-width:none;min-width:1180px}.preview-shell{min-height:100vh}.preview-page{padding:34px 36px 104px}.preview-switcher{z-index:20;position:fixed;top:14px;right:26px}.preview-switcher-button{background:linear-gradient(135deg, var(--preview-accent), var(--preview-accent-2));color:#fff;border:0;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;padding:0;transition:box-shadow .16s,filter .16s;display:inline-flex;position:relative;box-shadow:0 16px 36px #006dff47}.preview-switcher.open .preview-switcher-button,.preview-switcher:hover .preview-switcher-button{filter:saturate(1.08);box-shadow:0 18px 44px #006dff57}.switcher-dot-grid{grid-template-columns:repeat(2,6px);gap:4px;display:grid}.switcher-dot-grid i{opacity:.95;background:#fff;width:6px;height:6px;display:block}.switcher-chevron{opacity:.9;transform-origin:50%;border-top:5px solid #fff;border-left:4px solid #0000;border-right:4px solid #0000;width:0;height:0;transition:transform .16s;position:absolute;bottom:8px;right:10px}.preview-switcher.open .switcher-chevron,.preview-switcher:hover .switcher-chevron{transform:rotate(180deg)}.preview-switcher-menu{border:1px solid var(--preview-line);opacity:0;pointer-events:none;transform-origin:100% 0;background:#fff;border-radius:16px;gap:6px;width:280px;padding:10px;transition:opacity .16s,transform .18s;display:grid;position:absolute;top:60px;right:0;transform:translateY(-8px)scale(.96);box-shadow:0 22px 54px #0f17202e,0 10px 24px #006dff1a}.preview-switcher.open .preview-switcher-menu,.preview-switcher:hover .preview-switcher-menu,.preview-switcher:focus-within .preview-switcher-menu{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.switcher-menu-title{border-bottom:1px solid var(--preview-line);gap:3px;margin:0 2px 2px;padding:8px 10px 11px;display:grid}.switcher-menu-title span{color:var(--preview-muted);font-size:11px}.switcher-menu-title strong{color:var(--preview-text);font-size:14px}.preview-switcher-menu button{color:var(--preview-text);text-align:left;background:0 0;border-radius:12px;gap:4px;min-height:58px;padding:10px 12px 10px 14px;transition:background-color .16s,color .16s;display:grid;position:relative}.preview-switcher-menu button:before{content:"";opacity:0;background:0 0;border-radius:999px;width:3px;height:28px;transition:background-color .16s,opacity .16s;position:absolute;top:50%;left:6px;transform:translateY(-50%)}.preview-switcher-menu button.active,.preview-switcher-menu button:hover{color:#063f99;background:linear-gradient(135deg,#006dff1f,#2f86ff12)}.preview-switcher-menu button.active:before,.preview-switcher-menu button:hover:before{background:var(--preview-accent);opacity:1}.preview-switcher-menu button span{font-size:13px;font-weight:800;line-height:1.25}.preview-switcher-menu small{color:var(--preview-muted);line-height:1.45;transition:color .16s}.preview-switcher-menu button.active small,.preview-switcher-menu button:hover small{color:#356291}.preview-section{margin-top:18px}.first-section{margin-top:0}.preview-pane-enter-active,.preview-pane-leave-active{transition:opacity .16s,transform .18s}.preview-pane-enter-from{opacity:0;transform:translateY(8px)}.preview-pane-leave-to{opacity:0;transform:translateY(-6px)}.preview-tabs{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);grid-template-columns:repeat(var(--tab-count), 92px);z-index:18;background:#ffffffeb;border:0;border-radius:999px;align-items:center;padding:7px;display:grid;position:fixed;bottom:22px;left:50%;transform:translate(-50%);box-shadow:0 16px 42px #07152b29}.preview-tab-indicator{pointer-events:none;height:calc(100% - 14px);transform:translate3d(var(--tab-shift), 0, 0);z-index:0;background:linear-gradient(135deg,#006dff 0%,#1f7fff 52%,#3a8cff 100%);border-radius:999px;width:92px;transition:transform .26s cubic-bezier(.2,.82,.2,1),width .22s;position:absolute;top:7px;left:7px;box-shadow:0 8px 18px #006dff38}.preview-tabs button{box-shadow:none;color:var(--preview-muted);outline-offset:0;text-align:center;z-index:1;background:0 0;border:0;border-radius:999px;outline:0;justify-content:center;align-items:center;min-width:0;height:32px;padding:0 18px;line-height:1;transition:color .18s;display:inline-flex;position:relative}.preview-tabs button.active{color:#fff}.preview-tabs button:hover,.preview-tabs button:focus,.preview-tabs button:active{box-shadow:none;border:0;outline:0}.preview-tabs button:focus-visible{box-shadow:var(--preview-focus);outline:0}.preview-tabs span{font-size:13px;font-weight:800;line-height:1;display:block}.section-heading{justify-content:space-between;align-items:end;margin-bottom:10px;display:flex}.section-heading p{color:var(--preview-accent);margin:0 0 4px;font-size:12px;font-weight:800}.section-heading h2,.component-title h2{color:var(--preview-text);margin:0;font-size:18px}.section-heading span,.component-title span{color:var(--preview-muted);font-size:12px}.component-frame{background:var(--preview-panel);border:1px solid var(--preview-line);border-radius:12px;overflow:hidden;box-shadow:0 18px 40px #0f172014}.workbook-frame{height:720px}.mini-workbook{grid-template-rows:minmax(0,1fr) 34px;grid-template-columns:258px minmax(620px,1fr) 264px;height:100%;display:grid}.mini-workbook-main{grid-template-rows:auto minmax(0,1fr);min-width:0;display:grid}.tabs-row{grid-column:1/-1;min-width:0}.two-column{grid-template-columns:360px 360px;gap:18px;display:grid}.component-frame-fixed{grid-template-rows:auto 520px;display:grid}.component-title{border-bottom:1px solid var(--preview-line);justify-content:space-between;align-items:center;padding:14px;display:flex}.component-body{min-height:0;overflow:hidden}.sidebar-only{grid-template-columns:258px;display:grid}.smart-only{grid-template-columns:264px;display:grid}.dashboard-frame{height:680px}.mode-toggle{background:var(--preview-accent);border-radius:var(--preview-radius-sm);color:#fff;height:32px;padding:0 12px}.back-top-button{border:1px solid var(--preview-line);z-index:19;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;display:inline-flex;position:fixed;bottom:88px;right:26px;box-shadow:0 18px 42px #07152b33,0 8px 18px #006dff1f}.back-top-button span{border-left:6px solid #0000;border-right:6px solid #0000;border-bottom:8px solid var(--preview-accent);width:0;height:0}.back-top-button:hover{border-color:#006dff5c;box-shadow:0 20px 46px #07152b38,0 10px 22px #006dff2e}.back-top-enter-active,.back-top-leave-active{transition:opacity .15s,transform .17s}.back-top-enter-from,.back-top-leave-to{opacity:0;transform:translateY(8px)scale(.96)}.spec-grid{grid-template-columns:minmax(420px,.9fr) minmax(420px,.8fr);gap:18px;display:grid}.component-guideline-grid{grid-template-columns:minmax(440px,.8fr) minmax(420px,.7fr);gap:18px;display:grid}.spec-card{background:var(--preview-panel);border:1px solid var(--preview-line);border-radius:var(--preview-radius-lg);padding:22px;box-shadow:0 18px 40px #0f172014}.spec-kicker{color:var(--preview-accent);margin:0 0 6px;font-size:12px;font-weight:800}.spec-card h2{color:var(--preview-text);margin:0 0 16px;font-size:20px}.spec-note{color:var(--preview-muted);margin:12px 0 0;font-size:12px;line-height:1.65}.type-scale-list{gap:0;display:grid}.type-sample{color:var(--preview-text);border-bottom:1px solid #e1e8ef;grid-template-columns:92px minmax(0,1fr) 150px;gap:5px;padding:14px 0;display:grid}.type-sample:last-child{border-bottom:0}.type-sample span{color:var(--preview-accent);letter-spacing:0;font-size:12px;font-weight:800}.type-sample small{color:var(--preview-muted);justify-self:end;font-size:12px}.type-display strong{font-size:30px;font-weight:800;line-height:1.18}.type-title strong{font-size:24px;font-weight:700;line-height:1.25}.type-section strong{font-size:18px;font-weight:700;line-height:1.35}.type-body strong{color:#334640;font-size:14px;font-weight:600;line-height:1.55}.type-caption strong{color:var(--preview-muted);font-size:12px;line-height:1.45}.font-stack-sample{border-radius:var(--preview-radius-md);color:var(--preview-text);background:#f7fafc;border:1px solid #e1e8ef;margin-bottom:14px;padding:12px 14px;font-size:13px;font-weight:700}.text-behavior-grid{grid-template-columns:minmax(0,1fr) 150px;gap:10px;margin-bottom:16px;display:grid}.text-behavior-grid div{border-radius:var(--preview-radius-md);background:#f7fafc;gap:5px;min-width:0;padding:12px;display:grid}.text-behavior-grid span{color:var(--preview-muted);font-size:12px}.text-behavior-grid strong{color:var(--preview-text);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:14px;overflow:hidden}.numeric-sample{font-variant-numeric:tabular-nums;text-align:right}.spec-list{color:#344942;gap:10px;margin:0;padding-left:18px;line-height:1.7;display:grid}.component-state-grid,.interaction-demo{flex-wrap:wrap;gap:10px;display:flex}.sample-control,.focus-demo-button{border:1px solid var(--preview-line);color:var(--preview-text);background:#fff;border-radius:999px;height:34px;padding:0 16px;font-size:13px;font-weight:800;transition:background-color .16s,border-color .16s,box-shadow .16s,color .16s,opacity .16s}.sample-control:hover,.sample-control-hover,.focus-demo-button:hover{background:var(--preview-accent-soft);color:#0649ad;border-color:#006dff3d}.sample-control-active,.focus-demo-button.active{background:linear-gradient(135deg, var(--preview-accent), var(--preview-accent-2));color:#fff;border-color:#0000}.sample-control:focus-visible,.focus-demo-button:focus-visible{box-shadow:var(--preview-focus);outline:0}.sample-control:disabled,.focus-demo-button:disabled{color:#9aa7b7;cursor:not-allowed;opacity:1;background:#f1f5f9}.modal-demo{align-content:start;gap:14px;display:grid}.modal-demo p{color:var(--preview-muted);margin:0;font-size:13px;line-height:1.6}.mode-toggle.secondary{color:#245579;background:#fff;border-color:#c9d6e4}.mode-toggle.secondary:hover{color:#0649ad;background:#eef6ff;border-color:#006dff47}.preview-base-modal{gap:16px;width:min(520px,100vw - 48px);padding:22px;display:grid}.preview-base-modal header{gap:8px;display:grid}.preview-base-modal header span{color:#075bbf;background:#e7f1ff;justify-content:center;align-items:center;width:38px;height:22px;font-size:11px;font-weight:900;display:inline-flex}.preview-base-modal h2{color:var(--preview-text);margin:0;font-size:20px;line-height:1.25}.preview-base-modal p{color:var(--preview-muted);margin:0;font-size:13px;line-height:1.7}.preview-base-modal-grid{border:1px solid #d9e3ee;display:grid}.preview-base-modal-grid div{border-bottom:1px solid #d9e3ee;gap:5px;padding:11px 12px;display:grid}.preview-base-modal-grid div:last-child{border-bottom:0}.preview-base-modal-grid strong{color:var(--preview-text);font-size:13px}.preview-base-modal-grid small{color:var(--preview-muted);font-size:12px}.preview-base-modal footer{justify-content:flex-end;gap:10px;display:flex}.icon-spec-preview{grid-template-columns:repeat(3,minmax(300px,1fr));gap:18px;display:grid}.icon-spec-card{min-height:260px}.icon-size-grid,.field-icon-list,.text-icon-list,.tab-icon-row,.icon-rule-card{gap:10px;display:grid}.icon-size-row{border-bottom:1px solid #e1e8ef;grid-template-columns:42px 80px minmax(0,1fr);align-items:center;gap:12px;min-height:42px;padding-bottom:10px;display:grid}.icon-size-row strong{color:var(--preview-text);font-size:13px}.icon-size-row small{color:var(--preview-muted);line-height:1.45}.icon-cell{color:var(--preview-accent);background:#eef5ff;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.icon-cell-xs svg{width:13px;height:13px}.icon-cell-sm svg{width:14px;height:14px}.icon-cell-md svg{width:17px;height:17px}.icon-cell-lg svg{width:18px;height:18px}.icon-button-matrix{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.field-icon-list{margin-bottom:16px}.field-icon-item{color:#243632;background:#f7fafc;grid-template-columns:16px minmax(0,1fr);align-items:center;gap:8px;min-height:32px;padding:0 10px;font-size:13px;display:grid}.field-icon-item svg{color:#2d8c74;width:14px;height:14px}.field-icon-item.warning svg{color:#d9514e;width:13px;height:13px}.text-icon-list{grid-template-columns:repeat(2,max-content);align-items:start;margin-bottom:16px}.tab-icon-row{background:#e5ebe8;border-top:1px solid #b9c6c1;margin-bottom:16px;display:flex;overflow:hidden}.tab-icon-row button{color:#132f39;background:#fff;align-items:center;gap:5px;height:34px;padding:0 10px;font-size:12px;display:inline-flex}.tab-icon-row svg{width:14px;height:14px}.chart-icon-preview-grid{grid-template-columns:repeat(3,78px);gap:8px;margin-bottom:16px;display:grid}.icon-rule-list{font-size:12px}.icon-rule-block{color:#344942;background:#f7fafc;grid-template-columns:30px minmax(0,1fr);align-items:start;gap:12px;padding:12px;display:grid}.icon-rule-block>svg{color:var(--preview-accent);margin-top:1px}.icon-rule-block div{gap:4px;display:grid}.icon-rule-block strong{color:var(--preview-text);font-size:13px}.icon-rule-block span{color:var(--preview-muted);font-size:12px;line-height:1.6}.size-row{color:var(--preview-muted);border-bottom:1px solid #e1e8ef;grid-template-columns:100px 210px 1fr;align-items:center;gap:12px;min-height:54px;display:grid}.size-row span{color:var(--preview-text);font-weight:700}.size-row i{background:#eef5ff;border:1px solid #b9d5ff;display:block}.spacing-stack{align-items:end;gap:14px;min-height:120px;display:flex}.spacing-stack span{background:linear-gradient(180deg, #4a98ff, var(--preview-accent));color:#fff;place-items:end center;height:72px;padding-bottom:8px;font-size:11px;display:grid}.radius-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:18px;display:grid}.radius-grid div{color:var(--preview-muted);align-items:center;gap:8px;font-size:12px;display:grid}.radius-grid i{background:#eef5ff;border:1px solid #b9d5ff;width:100%;height:42px;display:block}.swatch-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.swatch{border-radius:var(--preview-radius-md);color:#344942;background:#f7fafc;border:1px solid #e1e8ef;align-items:center;gap:10px;min-height:46px;padding:8px;font-size:13px;font-weight:700;display:flex}.swatch i{background:var(--swatch);border:1px solid #00000014;width:38px;height:28px;display:block}.surface-stack{gap:10px;margin-bottom:16px;display:grid}.surface-sample{border-radius:var(--preview-radius-md);color:var(--preview-text);min-height:48px;padding:15px;font-size:13px;font-weight:700}.surface-page{background:var(--preview-bg);border:1px solid #d6dee8}.surface-panel{border:1px solid var(--preview-line);background:#fff;box-shadow:0 12px 28px #0f172014}.surface-soft{background:var(--preview-accent-soft);color:#0649ad;border:1px solid #bfd8ff}.layout-canvas{background:var(--preview-bg);border-radius:var(--preview-radius-lg);border:1px solid #d5dde8;grid-template-rows:minmax(130px,1fr) 34px;grid-template-columns:92px minmax(0,1fr) 92px;gap:8px;min-height:250px;padding:18px;display:grid;position:relative;overflow:hidden}.layout-canvas>div{border:1px solid var(--preview-line);color:var(--preview-muted);background:#fff;place-items:center;min-width:0;font-size:12px;font-weight:800;display:grid}.layout-sidebar{border-radius:var(--preview-radius-md) 0 0 var(--preview-radius-md)}.layout-main{color:var(--preview-text)!important}.layout-inspector{border-radius:0 var(--preview-radius-md) var(--preview-radius-md) 0}.layout-tabs-demo{grid-column:1/-1;border-radius:999px!important}.layout-float{background:linear-gradient(135deg, var(--preview-accent), var(--preview-accent-2));color:#fff;border-radius:999px;justify-content:center;align-items:center;width:38px;height:38px;font-size:12px;font-weight:800;display:inline-flex;position:absolute;right:12px}.layout-float.top{top:12px}.layout-float.bottom{border:1px solid var(--preview-line);color:var(--preview-accent);background:#fff;bottom:54px;box-shadow:0 12px 30px #07152b24}.motion-stack{gap:12px;display:grid}.motion-stack div{color:var(--preview-muted);grid-template-columns:160px minmax(0,1fr);align-items:center;gap:12px;font-size:13px;display:grid}.motion-stack span{background:linear-gradient(90deg, var(--preview-accent), var(--preview-accent-2));height:10px;width:var(--bar);border-radius:999px;display:block}.focus-demo-button:focus-visible,.focus-demo-button.active{box-shadow:var(--preview-focus)}@media (width<=1360px){.preview-page{padding-left:24px;padding-right:24px}.two-column{grid-template-columns:1fr 1fr}.spec-grid,.component-guideline-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto!important}.preview-pane-enter-active,.preview-pane-leave-active,.preview-switcher-button,.preview-switcher-menu,.back-top-enter-active,.back-top-leave-active,.sample-control,.focus-demo-button{transition-duration:1ms!important}}
