.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}@layer theme,base,components,utilities;@layer theme{@theme default{ --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --color-red-50: oklch(97.1% .013 17.38); --color-red-100: oklch(93.6% .032 17.717); --color-red-200: oklch(88.5% .062 18.334); --color-red-300: oklch(80.8% .114 19.571); --color-red-400: oklch(70.4% .191 22.216); --color-red-500: oklch(63.7% .237 25.331); --color-red-600: oklch(57.7% .245 27.325); --color-red-700: oklch(50.5% .213 27.518); --color-red-800: oklch(44.4% .177 26.899); --color-red-900: oklch(39.6% .141 25.723); --color-red-950: oklch(25.8% .092 26.042); --color-orange-50: oklch(98% .016 73.684); --color-orange-100: oklch(95.4% .038 75.164); --color-orange-200: oklch(90.1% .076 70.697); --color-orange-300: oklch(83.7% .128 66.29); --color-orange-400: oklch(75% .183 55.934); --color-orange-500: oklch(70.5% .213 47.604); --color-orange-600: oklch(64.6% .222 41.116); --color-orange-700: oklch(55.3% .195 38.402); --color-orange-800: oklch(47% .157 37.304); --color-orange-900: oklch(40.8% .123 38.172); --color-orange-950: oklch(26.6% .079 36.259); --color-amber-50: oklch(98.7% .022 95.277); --color-amber-100: oklch(96.2% .059 95.617); --color-amber-200: oklch(92.4% .12 95.746); --color-amber-300: oklch(87.9% .169 91.605); --color-amber-400: oklch(82.8% .189 84.429); --color-amber-500: oklch(76.9% .188 70.08); --color-amber-600: oklch(66.6% .179 58.318); --color-amber-700: oklch(55.5% .163 48.998); --color-amber-800: oklch(47.3% .137 46.201); --color-amber-900: oklch(41.4% .112 45.904); --color-amber-950: oklch(27.9% .077 45.635); --color-yellow-50: oklch(98.7% .026 102.212); --color-yellow-100: oklch(97.3% .071 103.193); --color-yellow-200: oklch(94.5% .129 101.54); --color-yellow-300: oklch(90.5% .182 98.111); --color-yellow-400: oklch(85.2% .199 91.936); --color-yellow-500: oklch(79.5% .184 86.047); --color-yellow-600: oklch(68.1% .162 75.834); --color-yellow-700: oklch(55.4% .135 66.442); --color-yellow-800: oklch(47.6% .114 61.907); --color-yellow-900: oklch(42.1% .095 57.708); --color-yellow-950: oklch(28.6% .066 53.813); --color-lime-50: oklch(98.6% .031 120.757); --color-lime-100: oklch(96.7% .067 122.328); --color-lime-200: oklch(93.8% .127 124.321); --color-lime-300: oklch(89.7% .196 126.665); --color-lime-400: oklch(84.1% .238 128.85); --color-lime-500: oklch(76.8% .233 130.85); --color-lime-600: oklch(64.8% .2 131.684); --color-lime-700: oklch(53.2% .157 131.589); --color-lime-800: oklch(45.3% .124 130.933); --color-lime-900: oklch(40.5% .101 131.063); --color-lime-950: oklch(27.4% .072 132.109); --color-green-50: oklch(98.2% .018 155.826); --color-green-100: oklch(96.2% .044 156.743); --color-green-200: oklch(92.5% .084 155.995); --color-green-300: oklch(87.1% .15 154.449); --color-green-400: oklch(79.2% .209 151.711); --color-green-500: oklch(72.3% .219 149.579); --color-green-600: oklch(62.7% .194 149.214); --color-green-700: oklch(52.7% .154 150.069); --color-green-800: oklch(44.8% .119 151.328); --color-green-900: oklch(39.3% .095 152.535); --color-green-950: oklch(26.6% .065 152.934); --color-emerald-50: oklch(97.9% .021 166.113); --color-emerald-100: oklch(95% .052 163.051); --color-emerald-200: oklch(90.5% .093 164.15); --color-emerald-300: oklch(84.5% .143 164.978); --color-emerald-400: oklch(76.5% .177 163.223); --color-emerald-500: oklch(69.6% .17 162.48); --color-emerald-600: oklch(59.6% .145 163.225); --color-emerald-700: oklch(50.8% .118 165.612); --color-emerald-800: oklch(43.2% .095 166.913); --color-emerald-900: oklch(37.8% .077 168.94); --color-emerald-950: oklch(26.2% .051 172.552); --color-teal-50: oklch(98.4% .014 180.72); --color-teal-100: oklch(95.3% .051 180.801); --color-teal-200: oklch(91% .096 180.426); --color-teal-300: oklch(85.5% .138 181.071); --color-teal-400: oklch(77.7% .152 181.912); --color-teal-500: oklch(70.4% .14 182.503); --color-teal-600: oklch(60% .118 184.704); --color-teal-700: oklch(51.1% .096 186.391); --color-teal-800: oklch(43.7% .078 188.216); --color-teal-900: oklch(38.6% .063 188.416); --color-teal-950: oklch(27.7% .046 192.524); --color-cyan-50: oklch(98.4% .019 200.873); --color-cyan-100: oklch(95.6% .045 203.388); --color-cyan-200: oklch(91.7% .08 205.041); --color-cyan-300: oklch(86.5% .127 207.078); --color-cyan-400: oklch(78.9% .154 211.53); --color-cyan-500: oklch(71.5% .143 215.221); --color-cyan-600: oklch(60.9% .126 221.723); --color-cyan-700: oklch(52% .105 223.128); --color-cyan-800: oklch(45% .085 224.283); --color-cyan-900: oklch(39.8% .07 227.392); --color-cyan-950: oklch(30.2% .056 229.695); --color-sky-50: oklch(97.7% .013 236.62); --color-sky-100: oklch(95.1% .026 236.824); --color-sky-200: oklch(90.1% .058 230.902); --color-sky-300: oklch(82.8% .111 230.318); --color-sky-400: oklch(74.6% .16 232.661); --color-sky-500: oklch(68.5% .169 237.323); --color-sky-600: oklch(58.8% .158 241.966); --color-sky-700: oklch(50% .134 242.749); --color-sky-800: oklch(44.3% .11 240.79); --color-sky-900: oklch(39.1% .09 240.876); --color-sky-950: oklch(29.3% .066 243.157); --color-blue-50: oklch(97% .014 254.604); --color-blue-100: oklch(93.2% .032 255.585); --color-blue-200: oklch(88.2% .059 254.128); --color-blue-300: oklch(80.9% .105 251.813); --color-blue-400: oklch(70.7% .165 254.624); --color-blue-500: oklch(62.3% .214 259.815); --color-blue-600: oklch(54.6% .245 262.881); --color-blue-700: oklch(48.8% .243 264.376); --color-blue-800: oklch(42.4% .199 265.638); --color-blue-900: oklch(37.9% .146 265.522); --color-blue-950: oklch(28.2% .091 267.935); --color-indigo-50: oklch(96.2% .018 272.314); --color-indigo-100: oklch(93% .034 272.788); --color-indigo-200: oklch(87% .065 274.039); --color-indigo-300: oklch(78.5% .115 274.713); --color-indigo-400: oklch(67.3% .182 276.935); --color-indigo-500: oklch(58.5% .233 277.117); --color-indigo-600: oklch(51.1% .262 276.966); --color-indigo-700: oklch(45.7% .24 277.023); --color-indigo-800: oklch(39.8% .195 277.366); --color-indigo-900: oklch(35.9% .144 278.697); --color-indigo-950: oklch(25.7% .09 281.288); --color-violet-50: oklch(96.9% .016 293.756); --color-violet-100: oklch(94.3% .029 294.588); --color-violet-200: oklch(89.4% .057 293.283); --color-violet-300: oklch(81.1% .111 293.571); --color-violet-400: oklch(70.2% .183 293.541); --color-violet-500: oklch(60.6% .25 292.717); --color-violet-600: oklch(54.1% .281 293.009); --color-violet-700: oklch(49.1% .27 292.581); --color-violet-800: oklch(43.2% .232 292.759); --color-violet-900: oklch(38% .189 293.745); --color-violet-950: oklch(28.3% .141 291.089); --color-purple-50: oklch(97.7% .014 308.299); --color-purple-100: oklch(94.6% .033 307.174); --color-purple-200: oklch(90.2% .063 306.703); --color-purple-300: oklch(82.7% .119 306.383); --color-purple-400: oklch(71.4% .203 305.504); --color-purple-500: oklch(62.7% .265 303.9); --color-purple-600: oklch(55.8% .288 302.321); --color-purple-700: oklch(49.6% .265 301.924); --color-purple-800: oklch(43.8% .218 303.724); --color-purple-900: oklch(38.1% .176 304.987); --color-purple-950: oklch(29.1% .149 302.717); --color-fuchsia-50: oklch(97.7% .017 320.058); --color-fuchsia-100: oklch(95.2% .037 318.852); --color-fuchsia-200: oklch(90.3% .076 319.62); --color-fuchsia-300: oklch(83.3% .145 321.434); --color-fuchsia-400: oklch(74% .238 322.16); --color-fuchsia-500: oklch(66.7% .295 322.15); --color-fuchsia-600: oklch(59.1% .293 322.896); --color-fuchsia-700: oklch(51.8% .253 323.949); --color-fuchsia-800: oklch(45.2% .211 324.591); --color-fuchsia-900: oklch(40.1% .17 325.612); --color-fuchsia-950: oklch(29.3% .136 325.661); --color-pink-50: oklch(97.1% .014 343.198); --color-pink-100: oklch(94.8% .028 342.258); --color-pink-200: oklch(89.9% .061 343.231); --color-pink-300: oklch(82.3% .12 346.018); --color-pink-400: oklch(71.8% .202 349.761); --color-pink-500: oklch(65.6% .241 354.308); --color-pink-600: oklch(59.2% .249 .584); --color-pink-700: oklch(52.5% .223 3.958); --color-pink-800: oklch(45.9% .187 3.815); --color-pink-900: oklch(40.8% .153 2.432); --color-pink-950: oklch(28.4% .109 3.907); --color-rose-50: oklch(96.9% .015 12.422); --color-rose-100: oklch(94.1% .03 12.58); --color-rose-200: oklch(89.2% .058 10.001); --color-rose-300: oklch(81% .117 11.638); --color-rose-400: oklch(71.2% .194 13.428); --color-rose-500: oklch(64.5% .246 16.439); --color-rose-600: oklch(58.6% .253 17.585); --color-rose-700: oklch(51.4% .222 16.935); --color-rose-800: oklch(45.5% .188 13.697); --color-rose-900: oklch(41% .159 10.272); --color-rose-950: oklch(27.1% .105 12.094); --color-slate-50: oklch(98.4% .003 247.858); --color-slate-100: oklch(96.8% .007 247.896); --color-slate-200: oklch(92.9% .013 255.508); --color-slate-300: oklch(86.9% .022 252.894); --color-slate-400: oklch(70.4% .04 256.788); --color-slate-500: oklch(55.4% .046 257.417); --color-slate-600: oklch(44.6% .043 257.281); --color-slate-700: oklch(37.2% .044 257.287); --color-slate-800: oklch(27.9% .041 260.031); --color-slate-900: oklch(20.8% .042 265.755); --color-slate-950: oklch(12.9% .042 264.695); --color-gray-50: oklch(98.5% .002 247.839); --color-gray-100: oklch(96.7% .003 264.542); --color-gray-200: oklch(92.8% .006 264.531); --color-gray-300: oklch(87.2% .01 258.338); --color-gray-400: oklch(70.7% .022 261.325); --color-gray-500: oklch(55.1% .027 264.364); --color-gray-600: oklch(44.6% .03 256.802); --color-gray-700: oklch(37.3% .034 259.733); --color-gray-800: oklch(27.8% .033 256.848); --color-gray-900: oklch(21% .034 264.665); --color-gray-950: oklch(13% .028 261.692); --color-zinc-50: oklch(98.5% 0 0); --color-zinc-100: oklch(96.7% .001 286.375); --color-zinc-200: oklch(92% .004 286.32); --color-zinc-300: oklch(87.1% .006 286.286); --color-zinc-400: oklch(70.5% .015 286.067); --color-zinc-500: oklch(55.2% .016 285.938); --color-zinc-600: oklch(44.2% .017 285.786); --color-zinc-700: oklch(37% .013 285.805); --color-zinc-800: oklch(27.4% .006 286.033); --color-zinc-900: oklch(21% .006 285.885); --color-zinc-950: oklch(14.1% .005 285.823); --color-neutral-50: oklch(98.5% 0 0); --color-neutral-100: oklch(97% 0 0); --color-neutral-200: oklch(92.2% 0 0); --color-neutral-300: oklch(87% 0 0); --color-neutral-400: oklch(70.8% 0 0); --color-neutral-500: oklch(55.6% 0 0); --color-neutral-600: oklch(43.9% 0 0); --color-neutral-700: oklch(37.1% 0 0); --color-neutral-800: oklch(26.9% 0 0); --color-neutral-900: oklch(20.5% 0 0); --color-neutral-950: oklch(14.5% 0 0); --color-stone-50: oklch(98.5% .001 106.423); --color-stone-100: oklch(97% .001 106.424); --color-stone-200: oklch(92.3% .003 48.717); --color-stone-300: oklch(86.9% .005 56.366); --color-stone-400: oklch(70.9% .01 56.259); --color-stone-500: oklch(55.3% .013 58.071); --color-stone-600: oklch(44.4% .011 73.639); --color-stone-700: oklch(37.4% .01 67.558); --color-stone-800: oklch(26.8% .007 34.298); --color-stone-900: oklch(21.6% .006 56.043); --color-stone-950: oklch(14.7% .004 49.25); --color-mauve-50: oklch(98.5% 0 0); --color-mauve-100: oklch(96% .003 325.6); --color-mauve-200: oklch(92.2% .005 325.62); --color-mauve-300: oklch(86.5% .012 325.68); --color-mauve-400: oklch(71.1% .019 323.02); --color-mauve-500: oklch(54.2% .034 322.5); --color-mauve-600: oklch(43.5% .029 321.78); --color-mauve-700: oklch(36.4% .029 323.89); --color-mauve-800: oklch(26.3% .024 320.12); --color-mauve-900: oklch(21.2% .019 322.12); --color-mauve-950: oklch(14.5% .008 326); --color-olive-50: oklch(98.8% .003 106.5); --color-olive-100: oklch(96.6% .005 106.5); --color-olive-200: oklch(93% .007 106.5); --color-olive-300: oklch(88% .011 106.6); --color-olive-400: oklch(73.7% .021 106.9); --color-olive-500: oklch(58% .031 107.3); --color-olive-600: oklch(46.6% .025 107.3); --color-olive-700: oklch(39.4% .023 107.4); --color-olive-800: oklch(28.6% .016 107.4); --color-olive-900: oklch(22.8% .013 107.4); --color-olive-950: oklch(15.3% .006 107.1); --color-mist-50: oklch(98.7% .002 197.1); --color-mist-100: oklch(96.3% .002 197.1); --color-mist-200: oklch(92.5% .005 214.3); --color-mist-300: oklch(87.2% .007 219.6); --color-mist-400: oklch(72.3% .014 214.4); --color-mist-500: oklch(56% .021 213.5); --color-mist-600: oklch(45% .017 213.2); --color-mist-700: oklch(37.8% .015 216); --color-mist-800: oklch(27.5% .011 216.9); --color-mist-900: oklch(21.8% .008 223.9); --color-mist-950: oklch(14.8% .004 228.8); --color-taupe-50: oklch(98.6% .002 67.8); --color-taupe-100: oklch(96% .002 17.2); --color-taupe-200: oklch(92.2% .005 34.3); --color-taupe-300: oklch(86.8% .007 39.5); --color-taupe-400: oklch(71.4% .014 41.2); --color-taupe-500: oklch(54.7% .021 43.1); --color-taupe-600: oklch(43.8% .017 39.3); --color-taupe-700: oklch(36.7% .016 35.7); --color-taupe-800: oklch(26.8% .011 36.5); --color-taupe-900: oklch(21.4% .009 43.1); --color-taupe-950: oklch(14.7% .004 49.3); --color-black: #000; --color-white: #fff; --spacing: .25rem; --breakpoint-sm: 40rem; --breakpoint-md: 48rem; --breakpoint-lg: 64rem; --breakpoint-xl: 80rem; --breakpoint-2xl: 96rem; --container-3xs: 16rem; --container-2xs: 18rem; --container-xs: 20rem; --container-sm: 24rem; --container-md: 28rem; --container-lg: 32rem; --container-xl: 36rem; --container-2xl: 42rem; --container-3xl: 48rem; --container-4xl: 56rem; --container-5xl: 64rem; --container-6xl: 72rem; --container-7xl: 80rem; --text-xs: .75rem; --text-xs--line-height: calc(1 / .75); --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875); --text-base: 1rem; --text-base--line-height: 1.5 ; --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125); --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25); --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5); --text-3xl: 1.875rem; --text-3xl--line-height: 1.2 ; --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25); --text-5xl: 3rem; --text-5xl--line-height: 1; --text-6xl: 3.75rem; --text-6xl--line-height: 1; --text-7xl: 4.5rem; --text-7xl--line-height: 1; --text-8xl: 6rem; --text-8xl--line-height: 1; --text-9xl: 8rem; --text-9xl--line-height: 1; --font-weight-thin: 100; --font-weight-extralight: 200; --font-weight-light: 300; --font-weight-normal: 400; --font-weight-medium: 500; --font-weight-semibold: 600; --font-weight-bold: 700; --font-weight-extrabold: 800; --font-weight-black: 900; --tracking-tighter: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / .05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1); --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1); --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / .05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / .05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / .05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / .05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / .15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / .12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / .15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / .1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / .15); --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / .15); --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / .2); --text-shadow-sm: 0px 1px 0px rgb(0 0 0 / .075), 0px 1px 1px rgb(0 0 0 / .075), 0px 2px 2px rgb(0 0 0 / .075); --text-shadow-md: 0px 1px 1px rgb(0 0 0 / .1), 0px 1px 2px rgb(0 0 0 / .1), 0px 2px 4px rgb(0 0 0 / .1); --text-shadow-lg: 0px 1px 2px rgb(0 0 0 / .1), 0px 3px 2px rgb(0 0 0 / .1), 0px 4px 8px rgb(0 0 0 / .1); --ease-in: cubic-bezier(.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, .2, 1); --ease-in-out: cubic-bezier(.4, 0, .2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite; --animate-bounce: bounce 1s infinite; @keyframes spin { to { transform: rotate(360deg); } } @keyframes ping { 75%, 100% { transform: scale(2); opacity: 0; } } @keyframes pulse { 50% { opacity: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(.8, 0, 1, 1); } 50% { transform: none; animation-timing-function: cubic-bezier(0, 0, .2, 1); } } --blur-xs: 4px; --blur-sm: 8px; --blur-md: 12px; --blur-lg: 16px; --blur-xl: 24px; --blur-2xl: 40px; --blur-3xl: 64px; --perspective-dramatic: 100px; --perspective-near: 300px; --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; --aspect-video: 16 / 9; --default-transition-duration: .15s; --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1); --default-font-family: --theme(--font-sans, initial); --default-font-feature-settings: --theme( --font-sans--font-feature-settings, initial ); --default-font-variation-settings: --theme( --font-sans--font-variation-settings, initial ); --default-mono-font-family: --theme(--font-mono, initial); --default-mono-font-feature-settings: --theme( --font-mono--font-feature-settings, initial ); --default-mono-font-variation-settings: --theme( --font-mono--font-variation-settings, initial ); }@theme default inline reference{ --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05); --drop-shadow: 0 1px 2px rgb(0 0 0 / .1), 0 1px 1px rgb(0 0 0 / .06); --radius: .25rem; --max-width-prose: 65ch; }}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:--theme(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:--theme(--default-font-feature-settings,normal);font-variation-settings:--theme(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:--theme(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:--theme(--default-mono-font-feature-settings,normal);font-variation-settings:--theme(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{@tailwind utilities;}:root{color-scheme:light;font-family:Inter,Segoe UI,Microsoft YaHei,PingFang SC,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-feature-settings:"cv01","ss03";font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}:root{--can-blue: #2563eb;--can-blue-bg: #eff6ff;--can-blue-border: #bfdbfe;--isotp-purple: #7c3aed;--isotp-purple-bg: #f5f3ff;--isotp-purple-border: #ddd6fe;--uds-orange: #ea580c;--uds-orange-bg: #fff7ed;--uds-orange-border: #fed7aa;--positive-green: #16a34a;--positive-green-bg: #f0fdf4;--positive-green-border: #bbf7d0;--warning-amber: #ca8a04;--warning-amber-bg: #fefce8;--warning-amber-border: #fef08a;--error-red: #dc2626;--error-red-bg: #fef2f2;--error-red-border: #fecaca;--highlight-yellow: #eab308}body{margin:0;min-width:320px;min-height:100vh;background:#f4f6f3;color:#17211f}button,input,textarea{font:inherit}button{cursor:pointer}code{border:1px solid #cfd9d4;border-radius:6px;background:#f7faf8;color:#0d3937;padding:.3rem .5rem;font-size:.88rem}.app-layout{display:grid;grid-template-columns:260px minmax(0,1fr) 320px;grid-template-rows:1fr auto;min-height:100vh}.app-layout-left{border-right:1px solid #dbe2dd;overflow-y:auto;background:#173f3b;color:#ecf4f1;position:relative}.app-layout-center{overflow-y:auto;min-width:0}.app-layout-right{border-left:1px solid #dbe2dd;overflow-y:auto;background:#fff}.app-layout-bottom{grid-column:1 / -1;border-top:1px solid #dbe2dd;background:#f8faf6;max-height:200px;overflow-y:auto}.knowledge-tree{padding:1rem;display:flex;flex-direction:column;gap:.25rem}.knowledge-tree-brand{display:flex;align-items:center;gap:.75rem;padding:.5rem 0 1rem;margin-bottom:.5rem;border-bottom:1px solid rgba(236,244,241,.12)}.knowledge-tree-brand strong{font-size:1.05rem;display:block}.knowledge-tree-brand span{color:#bad5ce;font-size:.78rem}.tree-section{display:flex;flex-direction:column}.tree-section-header{display:flex;align-items:center;gap:.5rem;padding:.55rem .6rem;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;border:none;background:transparent;color:#bad5ce;text-align:left;width:100%}.tree-section-header:hover{background:#ecf4f114}.tree-section-header.can{color:#93c5fd}.tree-section-header.isotp{color:#c4b5fd}.tree-section-header.uds{color:#fdba74}.tree-items{display:flex;flex-direction:column;padding-left:1.5rem}.tree-item{display:flex;align-items:center;gap:.4rem;padding:.4rem .6rem;border-radius:4px;font-size:.82rem;cursor:pointer;border:none;background:transparent;color:#d7e5e1;text-align:left;width:100%}.tree-item:hover{background:#ecf4f11f}.tree-item.active{background:#ecf4f1;color:#173f3b;font-weight:600}.tree-item-dot{width:6px;height:6px;border-radius:999px;flex-shrink:0}.tree-item-dot.can{background:var(--can-blue)}.tree-item-dot.isotp{background:var(--isotp-purple)}.tree-item-dot.uds{background:var(--uds-orange)}.tree-item-dot.quiz{background:var(--warning-amber)}.sidebar-toggle{align-items:center;background:#ffffff14;border:1px solid rgba(255,255,255,.14);border-radius:7px;color:#ecf4f1;display:inline-flex;height:32px;justify-content:center;position:absolute;right:.8rem;top:.9rem;width:32px;z-index:4}.layer-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.layer-badge.can{background:var(--can-blue-bg);color:var(--can-blue);border:1px solid var(--can-blue-border)}.layer-badge.isotp{background:var(--isotp-purple-bg);color:var(--isotp-purple);border:1px solid var(--isotp-purple-border)}.layer-badge.uds{background:var(--uds-orange-bg);color:var(--uds-orange);border:1px solid var(--uds-orange-border)}.app-shell{display:grid;grid-template-columns:272px minmax(0,1fr);min-height:100vh}.sidebar{background:#173f3b;color:#ecf4f1;display:flex;flex-direction:column;gap:1.25rem;min-height:100vh;padding:1.25rem;position:sticky;top:0}.brand-block{align-items:center;display:flex;gap:.75rem;min-height:58px}.brand-block strong{display:block;font-size:1.12rem}.brand-block span,.sidebar-note span,.eyebrow,.topbar-metrics span,.result-block span,.byte-editor-summary span,.payload-stats span,.quiz-toolbar span{color:#6c7975;font-size:.78rem;letter-spacing:0;text-transform:uppercase}.brand-block span,.sidebar-note span{color:#bad5ce}.module-nav{display:grid;gap:.5rem}.nav-item{align-items:center;background:transparent;border:1px solid rgba(236,244,241,.16);border-radius:8px;color:#ecf4f1;display:flex;gap:.75rem;min-height:44px;padding:.7rem .8rem;text-align:left}.nav-item:hover,.nav-item.active{background:#ecf4f1;color:#173f3b}.sidebar-note{border:1px solid rgba(236,244,241,.16);border-radius:8px;margin-top:auto;padding:.9rem}.sidebar-note p{color:#d7e5e1;font-size:.88rem;line-height:1.55;margin:.35rem 0 0}.workspace{min-width:0;padding:1.25rem}.topbar{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin:0 auto 1rem;max-width:1680px}.topbar h1{font-size:clamp(1.45rem,2vw,2.1rem);line-height:1.2;margin:.2rem 0 0}.topbar-metrics{display:grid;gap:.65rem;grid-template-columns:repeat(3,minmax(118px,1fr));min-width:420px}.topbar-metrics div,.byte-editor-summary div,.payload-stats,.quiz-toolbar div{background:var(--surface);border:1px solid var(--line);border-radius:8px;min-height:64px;padding:.75rem}.topbar-metrics strong{display:block;font-size:1rem;margin-top:.25rem;overflow-wrap:anywhere}.metric-ok strong{color:var(--green)}.metric-error strong{color:var(--red)}.content-region{margin:0 auto;max-width:1680px}.module-grid{display:grid;gap:1rem}.module-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.span-2{grid-column:1 / -1}.surface{background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);min-width:0;padding:1rem}.sketch-board{background:linear-gradient(#fff 27px,#dce2da8c 28px),linear-gradient(90deg,#fff 27px,#dce2da80 28px);background-color:#fffdfa;background-size:28px 28px;border:2px solid #273b37;border-radius:8px;box-shadow:5px 5px #273b371f;display:grid;gap:1rem;margin-bottom:1rem;min-width:0;padding:1rem;position:relative}.sketch-board:after{border:1px dashed rgba(39,59,55,.28);border-radius:8px;content:"";top:6px;right:6px;bottom:6px;left:6px;pointer-events:none;position:absolute}.sketch-title{align-items:flex-start;display:flex;gap:.7rem;position:relative;z-index:1}.sketch-title>svg{background:#fff1cc;border:2px solid #273b37;border-radius:8px;color:#273b37;flex:0 0 auto;height:38px;padding:.45rem;width:38px}.sketch-title span{color:#5f6966;display:block;font-size:.82rem}.sketch-title h3{font-size:1.05rem;line-height:1.35;margin:.15rem 0 0}.sketch-chain{display:grid;gap:1rem;position:relative;z-index:1}.sketch-chain.three{grid-template-columns:repeat(3,minmax(0,1fr))}.sketch-chain article,.can-visual,.timeline-card,.uds-message-grid article{background:#ffffffe0;border:2px solid #273b37;border-radius:8px;box-shadow:3px 3px #273b371f;min-width:0;padding:.85rem}.sketch-chain article{display:grid;gap:.65rem}.sketch-chain article strong,.timeline-card strong,.uds-message-grid article>strong{font-size:1rem}.sketch-chain article p,.sketch-notes p,.timeline-card p{color:#4f5f5a;line-height:1.58;margin:0}.sketch-byte-strip{display:grid;gap:.45rem;grid-template-columns:repeat(auto-fit,minmax(112px,1fr))}.sketch-byte{border:2px solid #273b37;border-radius:8px;display:grid;gap:.15rem;min-height:92px;padding:.55rem;position:relative}.sketch-byte:before{background:#273b371f;border-radius:999px;content:"";height:7px;position:absolute;right:10px;top:10px;width:7px}.sketch-byte span{color:#4f5f5a;font-size:.74rem}.sketch-byte strong{font-family:Cascadia Mono,Consolas,monospace;font-size:1.15rem;overflow-wrap:anywhere}.sketch-byte small{color:#5f6966;line-height:1.35}.sketch-byte.teal{background:#e9f6f2}.sketch-byte.amber{background:#fff4d7}.sketch-byte.blue{background:#eaf2ff}.sketch-byte.green{background:#e9f8ed}.sketch-byte.red{background:#fff0ed}.can-visual{display:grid;gap:.8rem;position:relative;z-index:1}.bus-line{align-items:center;display:grid;gap:.55rem;grid-template-columns:minmax(90px,auto) minmax(160px,1fr) minmax(90px,auto)}.bus-line strong{border-bottom:4px solid #273b37;color:#173f3b;min-height:30px;text-align:center}.bus-line span{background:#fff;border:2px solid #273b37;border-radius:999px;font-weight:700;padding:.45rem .7rem;text-align:center}.sketch-notes{display:grid;gap:.45rem;grid-template-columns:repeat(3,minmax(0,1fr));position:relative;z-index:1}.sketch-notes p{background:#fff8e9;border:1px dashed #c58b26;border-radius:8px;padding:.65rem}.isotp-lanes{display:grid;gap:.8rem;grid-template-columns:120px minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) 120px;position:relative;z-index:1}.isotp-lanes.single{grid-template-columns:120px minmax(0,1fr) 120px}.lane-label{align-self:center;background:#fff;border:2px solid #273b37;border-radius:999px;font-weight:700;padding:.55rem .7rem;text-align:center}.lane-label.tester{grid-column:1}.lane-label.ecu{grid-column:-2}.timeline-card{display:grid;gap:.5rem;position:relative}.timeline-card:before,.timeline-card:after{color:#273b37;content:"----";font-weight:800;position:absolute;top:50%;transform:translateY(-50%)}.timeline-card:before{left:-44px}.timeline-card:after{right:-44px}.timeline-card.sf,.timeline-card.ff{background:#e9f6f2}.timeline-card.fc{background:#fff4d7}.timeline-card.cf{background:#eaf2ff}.decision-strip{display:flex;flex-wrap:wrap;gap:.35rem;position:relative;z-index:1}.decision-item{background:#fffc;border:2px solid #273b37;border-radius:8px;display:grid;gap:.12rem;padding:.7rem;flex:1 1 140px;min-height:58px}.decision-item span{font-size:.72rem;color:#63716d}.decision-item strong{font-family:Cascadia Mono,Consolas,monospace;font-size:.92rem}.uds-flow-toolbar{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.5rem;position:relative;z-index:1}.uds-message-grid{display:grid;gap:1rem;position:relative;z-index:1}.uds-message-grid article{display:grid;gap:.55rem}.uds-message-grid article.negative{background:#fff0ed;border-color:var(--red)}.uds-message-grid article.positive{background:#e9f8ed;border-color:var(--green)}.uds-field{display:grid;gap:.12rem}.uds-field span{font-size:.72rem;color:#63716d}.uds-field strong{font-family:Cascadia Mono,Consolas,monospace;font-size:.92rem}.nrc-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.nrc-card{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.9rem}.nrc-card h3{font-size:.95rem;margin:0 0 .25rem}.nrc-card code{background:var(--surface-alt);border:1px solid var(--line)}.nrc-card p{color:#4f5f5a;font-size:.85rem;line-height:1.55}.nrc-card.error{border-color:var(--red);background:var(--error-red-bg)}.quiz-toolbar{display:flex;gap:1rem;flex-wrap:wrap}.quiz-card{background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:1rem;margin-top:1rem}.quiz-card h3{font-size:1rem;line-height:1.45}.quiz-options{display:grid;gap:.5rem;margin:.75rem 0}.quiz-option{align-items:center;background:#f9fafb;border:1px solid var(--line);border-radius:6px;display:flex;gap:.65rem;min-height:44px;padding:.65rem .8rem;text-align:left;width:100%}.quiz-option:hover{background:#f0fdf4;border-color:var(--green)}.quiz-option.correct{background:var(--positive-green-bg);border-color:var(--green)}.quiz-option.wrong{background:var(--error-red-bg);border-color:var(--red)}.quiz-explanation{background:#fffbeb;border:1px solid var(--warning-amber-border);border-radius:6px;margin-top:.75rem;padding:.75rem;font-size:.88rem;line-height:1.55;color:#92400e}.workspace-tailwind{padding:1.25rem;min-width:0}.topbar-tailwind{align-items:center;display:flex;gap:1rem;justify-content:space-between;flex-wrap:wrap;margin-bottom:1rem}.topbar-title{font-size:clamp(1.3rem,1.8vw,1.8rem);line-height:1.2;margin:.15rem 0 0;font-weight:700}.eyebrow-tailwind{color:#6c7975;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;margin:0}.topbar-metrics-tailwind{display:grid;gap:.5rem;grid-template-columns:repeat(3,minmax(100px,1fr))}.topbar-metrics-tailwind div{background:#fff;border:1px solid #dbe2dd;border-radius:8px;padding:.6rem .75rem;min-height:56px}.topbar-metrics-tailwind span{color:#6c7975;font-size:.72rem;text-transform:uppercase;display:block}.topbar-metrics-tailwind strong{display:block;font-size:.95rem;margin-top:.2rem}.metric-ok-tailwind strong{color:#16825d}.metric-error-tailwind strong{color:#dc2626}.content-region-tailwind{min-width:0}.explanation-panel{padding:1rem;display:flex;flex-direction:column;gap:1rem}.panel-section{display:flex;flex-direction:column;gap:.5rem}.panel-label{font-size:.7rem;text-transform:uppercase;color:#6c7975;letter-spacing:.04em}.panel-module-title{display:flex;align-items:center;gap:.5rem}.panel-module-title h3{font-size:1.05rem;margin:0;font-weight:700}.panel-description{font-size:.85rem;color:#4f5f5a;line-height:1.55;margin:0}.protocol-stats{display:flex;flex-direction:column;gap:.35rem}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:.35rem .5rem;background:#f9fafb;border-radius:6px;font-size:.82rem}.stat-row span{color:#6c7975}.stat-row code{font-size:.82rem;padding:.15rem .4rem;background:#f0fdf4;border:1px solid #bbf7d0}.text-green{color:#16825d}.text-red{color:#dc2626}.text-muted{color:#6c7975}.footer-frame-log{padding:.65rem 1rem;display:flex;align-items:flex-start;gap:.75rem;font-size:.8rem}.footer-label{font-weight:600;color:#4f5f5a;white-space:nowrap;padding-top:.1rem}.footer-bytes{font-family:Cascadia Mono,Consolas,monospace;font-size:.78rem;color:#0d3937;background:#f0faf6;border:1px solid #cbd5d1;border-radius:4px;padding:.3rem .55rem;overflow-wrap:anywhere;flex:1}.service-swimlane-board{position:relative;z-index:1}.swimlane-heads{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.6rem}.swimlane-heads span{text-align:center;font-weight:800;font-size:.85rem;letter-spacing:.04em;padding:.3rem 0;border-radius:999px;background:#fff;border:2px solid #273b37}.swimlane-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1rem;position:relative}.swimlane-lifeline{position:absolute;top:0;bottom:0;width:2px;border-radius:1px;background:#273b37;opacity:.35}.swimlane-lifeline.tester{left:calc(25% - 1px)}.swimlane-lifeline.ecu{left:calc(75% - 1px)}.swimlane-step{display:flex;align-items:flex-start;gap:.4rem;padding:.45rem .6rem;border:1.5px solid #273b37;border-radius:6px;background:#ffffffe6;cursor:pointer;text-align:left;font-family:inherit;font-size:.78rem;line-height:1.4;transition:box-shadow .15s;min-height:38px;position:relative;z-index:1}.swimlane-step:hover{box-shadow:2px 2px #273b3726}.swimlane-step.active{box-shadow:0 0 0 2px #273b37}.swimlane-step.tester{grid-column:1;margin-right:.75rem}.swimlane-step.ecu{grid-column:2;margin-left:.75rem}.swimlane-step.internal{grid-column:1 / -1;justify-self:center;width:60%;border-style:dashed;background:#faf9f0}.swimlane-step.tester:after,.swimlane-step.ecu:before{content:"";position:absolute;top:50%;width:.6rem;height:1.5px;background:#273b37}.swimlane-step.tester:after{right:-.6rem}.swimlane-step.ecu:before{left:-.6rem}.swimlane-step.tester:after{clip-path:polygon(0 40%,100% 50%,0 60%)}.swimlane-step.ecu:before{clip-path:polygon(100% 40%,0 50%,100% 60%)}.swimlane-step.teal{background:#e9f6f2}.swimlane-step.amber{background:#fff4d7}.swimlane-step.blue{background:#eaf2ff}.swimlane-step.green{background:#e9f8ed}.swimlane-step.red{background:#fff0ed;border-color:var(--red);color:#991b1b}.swimlane-step.red:after,.swimlane-step.red:before{background:#dc2626}.sequence-index{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:#273b37;color:#fff;font-size:.65rem;font-weight:800;flex-shrink:0}.swimlane-step.red .sequence-index{background:#dc2626}.swimlane-step strong{display:block;font-size:.78rem;line-height:1.25}.swimlane-step code{display:block;margin-top:.2rem;padding:.2rem .4rem;font-size:.7rem;background:#273b370f;border-radius:3px;border:none}.swimlane-progress{margin-top:.5rem;height:4px;background:#dbe2dd;border-radius:2px}.swimlane-progress span{display:block;height:100%;border-radius:2px;background:#273b37;transition:width .2s}.service-step-inspector{margin-top:.6rem;padding:.7rem;background:#faf9f0;border:1px dashed #b0b8b4;border-radius:6px;font-size:.82rem;line-height:1.5}.service-step-inspector strong{display:block;margin-bottom:.2rem}.service-step-inspector p{color:#4f5f5a;margin:.2rem 0}.service-overview-card{display:flex;gap:1rem;align-items:center;padding:.6rem .8rem;background:#fffc;border:1.5px solid #273b37;border-radius:6px;margin-bottom:.75rem;font-size:.82rem}.service-overview-card strong{display:block;font-size:.9rem}.service-overview-card p{color:#4f5f5a;margin:.15rem 0 0;font-size:.78rem}.response-rule-card{flex-shrink:0;padding:.3rem .6rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:4px;font-size:.72rem;text-align:center}.response-rule-card code{font-size:.78rem;border:none;padding:0;background:none}.response-rule-card small{display:block;color:#6b7a74;font-size:.68rem;margin-top:.15rem}.mini-flow-board{padding:.8rem!important}.mini-flow-row{display:flex;flex-direction:column;gap:.4rem}.mini-flow-node{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;border:1.5px solid #273b37;border-radius:6px;background:#ffffffe6;font-size:.78rem;line-height:1.3;position:relative}.mini-flow-node:after{content:"↓";position:absolute;bottom:-1rem;left:50%;transform:translate(-50%);font-size:.8rem;color:#273b37;font-weight:800}.mini-flow-node:last-child:after{content:none}.mini-flow-node em{font-size:.68rem;color:#5f6966;display:block;font-style:normal}.mini-flow-node strong{font-size:.78rem}.mini-flow-node p{margin:0;font-size:.72rem;color:#4f5f5a;flex:1}.mini-flow-node code{font-size:.68rem;padding:.1rem .3rem;background:#273b370f;border-radius:3px;border:none}.mini-flow-node span{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;background:#273b37;color:#fff;font-size:.6rem;font-weight:800;flex-shrink:0}.mini-flow-node.teal{border-left:3px solid #0f766e}.mini-flow-node.amber{border-left:3px solid #b7791f}.mini-flow-node.red{border-left:3px solid #b42318;background:#fff0ed}.mini-flow-node.green{border-left:3px solid #16825d;background:#e9f8ed}.footer-frame-log{padding:.45rem 1rem;display:flex;align-items:center;gap:.5rem;font-size:.72rem;overflow-x:auto}.footer-label{font-weight:700;color:#4f5f5a;white-space:nowrap;font-size:.68rem;text-transform:uppercase;letter-spacing:.04em}.footer-lane{display:flex;align-items:center;gap:.3rem;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;white-space:nowrap}.footer-lane.can{background:#eff6ff;border:1px solid #bfdbfe}.footer-lane.isotp{background:#f5f3ff;border:1px solid #ddd6fe}.footer-lane.uds{background:#fff7ed;border:1px solid #fed7aa}.footer-lane span{font-weight:600;font-size:.62rem;text-transform:uppercase}.footer-lane code{font-size:.68rem;padding:0;border:none;background:none}.footer-arrow{color:#a0aba7;font-weight:700;font-size:.7rem}.footer-status{padding:.2rem .5rem;border-radius:4px;font-size:.68rem;font-weight:600;white-space:nowrap}.footer-status.ok{background:#f0fdf4;border:1px solid #bbf7d0;color:#15803d}.footer-status.err{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.bit-cell{border-color:#dbe2dd!important}.validation-panel article.error-layer{border-right-width:4px!important;background:#fef2f2!important}.layer-card-error-dot{width:6px;height:6px;border-radius:50%;background:#dc2626;flex-shrink:0;animation:pulse-dot 1.5s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.quiz-header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem;padding:.6rem .8rem;background:#f8faf6;border:1px solid #dbe2dd;border-radius:8px}.quiz-global-progress{flex:1;display:flex;align-items:center;gap:.5rem}.quiz-global-progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.quiz-global-progress-fill{height:100%;border-radius:4px;background:var(--teal);transition:width .3s}.quiz-global-progress-text{font-size:.78rem;font-weight:600;color:#4f5f5a;white-space:nowrap}.layer-map{display:flex;align-items:center;gap:0;flex-wrap:wrap;position:relative;z-index:1}.layer-map article{display:flex;align-items:center;gap:.4rem;padding:.45rem .65rem;border:1.5px solid #273b37;border-radius:6px;background:#ffffffe6;font-size:.78rem;min-height:36px}.layer-map article strong{font-size:.78rem;white-space:nowrap}.layer-map article span{font-size:.7rem;color:#5f6966}.layer-arrow{font-size:.9rem;font-weight:800;color:#273b37;margin:0 .3rem;position:relative;z-index:1}.layer-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px}.layer-detail-cell{padding:8px;border-radius:6px;font-size:.74rem;line-height:1.35}.layer-detail-cell.ok{background:#f8faf6;border:1px solid #dbe2dd}.layer-detail-cell.err{background:#fef2f2;border:1px solid #fecaca}.layer-detail-cell strong{display:block;font-size:.76rem;margin-bottom:2px}:root{--surface: #ffffff;--surface-alt: #f8faf6;--ink: #17211f;--muted: #66736f;--line: #dbe2dd;--teal: #0f766e;--teal-dark: #164844;--amber: #b7791f;--red: #b42318;--green: #16825d;--blue: #2563a9;--shadow: 0 16px 45px rgba(34, 47, 43, .1)}.app-layout.no-panel{grid-template-columns:260px minmax(0,1fr)}.app-layout.sidebar-collapsed,.app-layout.no-panel.sidebar-collapsed{grid-template-columns:68px minmax(0,1fr)}.sidebar-collapsed .app-layout-left{overflow-x:hidden}.sidebar-collapsed .knowledge-tree{align-items:center;padding:3.25rem .5rem .75rem}.sidebar-collapsed .knowledge-tree-brand{border-bottom:0;justify-content:center;margin:0;padding:0 0 .6rem}.sidebar-collapsed .knowledge-tree-brand div,.sidebar-collapsed .tree-section-header span,.sidebar-collapsed .tree-section-header em,.sidebar-collapsed .tree-items,.sidebar-collapsed .tree-item span,.sidebar-collapsed .tree-item em{display:none}.sidebar-collapsed .tree-section-header{justify-content:center;padding:.55rem;width:38px}.sidebar-collapsed .tree-chevron,.sidebar-collapsed .tree-chevron-spacer{display:none}.sidebar-collapsed .tree-section-header svg{height:18px;width:18px}.sidebar-collapsed .sidebar-toggle{right:.95rem}.workspace-tailwind{padding:1rem 1.25rem 1.5rem}.topbar-tailwind{background:#ffffffb8;border:1px solid rgba(219,226,221,.9);border-radius:8px;margin-bottom:1rem;padding:.85rem 1rem}.topbar-title{font-size:1.45rem}.topbar-metrics-tailwind div{box-shadow:none}.home-dashboard{display:grid;gap:1rem}.home-hero-panel,.learning-path-panel{background:#fff;border:1px solid #dbe2dd;border-radius:8px;box-shadow:var(--shadow)}.home-hero-panel{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);gap:1rem;padding:1.35rem}.home-hero-copy h2{font-size:1.75rem;line-height:1.22;margin:.25rem 0 .65rem;max-width:820px}.home-hero-copy p{color:#4f5f5a;line-height:1.7;margin:0;max-width:780px}.home-next-steps{display:grid;gap:.6rem;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:1.15rem;max-width:760px}.home-next-steps article{background:#f9fbfae0;border:1px solid rgba(0,0,0,.06);border-radius:8px;box-shadow:#0000000a 0 1px 2px;padding:.75rem .85rem}.home-next-steps span{color:var(--console-muted, #5f6b66);display:block;font-size:.68rem;font-weight:760;text-transform:uppercase}.home-next-steps strong{display:block;font-size:.96rem;margin-top:.25rem}.home-next-steps small{color:var(--console-muted, #5f6b66);display:block;line-height:1.45;margin-top:.25rem}.home-status-strip{display:grid;gap:.65rem}.home-status-strip div{background:#f8faf6;border:1px solid #dbe2dd;border-radius:8px;padding:.75rem .85rem}.home-status-strip div.ok{background:#f0fdf4;border-color:#bbf7d0}.home-status-strip div.bad{background:#fff7ed;border-color:#fed7aa}.home-status-strip span,.module-entry span,.path-timeline span{color:#6c7975;display:block;font-size:.72rem;font-weight:700;text-transform:uppercase}.home-status-strip strong{display:block;font-size:1.1rem;margin-top:.2rem}.home-status-strip small{color:#5d6a66;display:block;line-height:1.4;margin-top:.25rem;overflow-wrap:anywhere}.module-entry-grid{display:grid;gap:1rem;grid-template-columns:repeat(3,minmax(0,1fr))}.module-entry{background:#fff;border:1px solid #dbe2dd;border-radius:8px;color:inherit;display:grid;gap:.45rem;min-height:190px;padding:1rem;text-decoration:none;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.module-entry:hover{border-color:#9db2ac;box-shadow:var(--shadow);transform:translateY(-1px)}.module-entry.can svg{color:var(--can-blue)}.module-entry.uds svg{color:var(--uds-orange)}.module-entry.quiz svg{color:var(--warning-amber)}.module-entry strong{font-size:1.2rem}.module-entry p{color:#4f5f5a;line-height:1.6;margin:0}.module-entry em{align-items:center;color:#173f3b;display:inline-flex;font-style:normal;font-weight:700;gap:.3rem;margin-top:auto}.learning-path-panel{padding:1rem}.path-timeline{display:grid;gap:.75rem;grid-template-columns:repeat(4,minmax(0,1fr))}.path-timeline article{border-left:3px solid #173f3b;background:#f8faf6;border-radius:6px;padding:.75rem}.path-timeline strong{display:block;margin-top:.15rem}.path-timeline p{color:#5d6a66;font-size:.86rem;line-height:1.5;margin:.35rem 0 0}.home-reference-grid{display:grid;gap:1rem;grid-template-columns:1fr 1fr}.surface{border-radius:8px;box-shadow:none}.section-heading{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between}.section-heading h2{line-height:1.25}.control-row input,.byte-input-grid input,.quiz-input,.sid-search input,.collapse-body input{background:#fff;border:1px solid #cfd9d4;border-radius:6px;color:#17211f;min-height:38px;padding:.45rem .6rem}.control-row input:focus,.byte-input-grid input:focus,.quiz-input:focus,.sid-search input:focus,.collapse-body input:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f;outline:none}.control-row{align-items:end;display:grid;gap:.75rem;grid-template-columns:minmax(180px,1fr) 120px;margin:.75rem 0}.control-row label,.byte-input-grid label{color:#66736f;display:grid;gap:.3rem;font-size:.76rem;font-weight:700;text-transform:uppercase}.frame-bytes{display:grid;gap:.5rem;grid-template-columns:repeat(8,minmax(0,1fr));margin:.75rem 0}.frame-bytes.compact{gap:.25rem}.byte-cell{background:#f8faf6;border:1px solid #dbe2dd;border-radius:8px;color:#17211f;display:grid;gap:.25rem;min-height:64px;padding:.55rem;text-align:left}.byte-cell:hover,.byte-cell.selected{background:#eaf2ff;border-color:#93c5fd}.byte-cell.active-range{background:#eef7f4;border-color:#0f766e}.byte-label{color:#66736f;font-size:.68rem;font-weight:800}.byte-cell strong{font-family:Cascadia Mono,Consolas,monospace;font-size:1rem}.byte-input-grid{display:grid;gap:.65rem;grid-template-columns:repeat(4,minmax(0,1fr))}.byte-editor-summary{display:grid;gap:.5rem;grid-template-columns:repeat(3,minmax(0,1fr));margin:.75rem 0}.byte-editor-summary div{background:#f8faf6;border:1px solid #dbe2dd;border-radius:8px;padding:.65rem}.byte-editor-summary strong{display:block;overflow-wrap:anywhere}.bit-grid{display:grid;gap:.45rem;grid-template-columns:repeat(8,minmax(0,1fr))}.bit-cell{background:#fff;border:1px solid #dbe2dd;border-radius:8px;display:grid;gap:.25rem;min-height:58px;padding:.45rem;text-align:center}.bit-cell span{color:#66736f;font-size:.68rem}.bit-cell.on{background:#173f3b;color:#fff}.bit-cell.on span{color:#cfe2dc}.uds-workspace{display:grid;gap:1rem}.uds-workspace>.section-heading{background:#fff;border:1px solid #dbe2dd;border-radius:8px;padding:1rem}.uds-command-strip{align-items:center;background:#fff;border:1px solid #dbe2dd;border-radius:8px;display:grid;gap:.75rem;grid-template-columns:minmax(260px,1fr) auto auto;padding:.75rem}.sid-search{align-items:center;display:flex;gap:.5rem;min-width:0}.sid-search input{min-width:0;width:100%}.view-toggle,.sid-stepper,.layer-mode-strip{align-items:center;display:flex;gap:.35rem}.view-toggle,.sid-stepper{background:#f8faf6;border:1px solid #dbe2dd;border-radius:8px;padding:.25rem}.view-toggle button,.sid-stepper button,.layer-mode-strip button,.scenario-rail button,.sid-row,.collapse-trigger,.state-node,.security-state,.diagram-sidebar button,.quiz-header button,.option{border:1px solid transparent;border-radius:6px;background:transparent;color:inherit;font:inherit}.view-toggle button,.sid-stepper button{align-items:center;display:inline-flex;font-size:.82rem;font-weight:700;justify-content:center;min-height:30px;padding:.25rem .55rem}.view-toggle button.active,.sid-stepper button:hover,.layer-mode-strip button.active{background:#173f3b;color:#fff}.sid-stepper span{font-weight:800;min-width:4.2rem;text-align:center}.layer-mode-strip,.scenario-rail{overflow-x:auto;padding-bottom:.1rem}.layer-mode-strip button{background:#fff;border-color:#dbe2dd;min-width:190px;padding:.75rem;text-align:left}.layer-mode-strip strong,.layer-mode-strip span,.scenario-rail strong,.scenario-rail span{display:block}.layer-mode-strip span,.scenario-rail span{color:#66736f;font-size:.78rem;line-height:1.35;margin-top:.2rem}.scenario-rail{display:grid;gap:.5rem;grid-template-columns:repeat(6,minmax(150px,1fr))}.scenario-rail button{background:#fff;border-color:#dbe2dd;padding:.7rem;text-align:left}.scenario-rail button.active{background:#fff7ed;border-color:#fdba74}.uds-main-grid{align-items:start;display:grid;gap:1rem;grid-template-columns:240px minmax(0,1fr) 300px}.sid-catalog-rail,.uds-main-panel,.uds-side-panel,.trainer-panel,.decision-board,.diagram-gallery{min-width:0}.sid-catalog-rail,.trainer-panel,.decision-board,.diagram-gallery{background:#fff;border:1px solid #dbe2dd;border-radius:8px}.sid-catalog-rail{max-height:calc(100vh - 220px);overflow:hidden;position:sticky;top:1rem}.panel-title-row{align-items:center;display:flex;justify-content:space-between;gap:.75rem}.panel-title-row span{color:#66736f;display:block;font-size:.7rem;font-weight:700;text-transform:uppercase}.panel-title-row strong{display:block}.sid-catalog-rail>.panel-title-row,.diagram-gallery>.panel-title-row,.decision-board>.panel-title-row{padding:.8rem}.catalog-count{background:#f0fdf4;border-radius:999px;color:#15803d!important;padding:.2rem .5rem}.sid-catalog-scroll{max-height:calc(100vh - 290px);overflow-y:auto;padding:0 .55rem .65rem}.sid-group h3{color:#4f5f5a;font-size:.75rem;margin:.7rem 0 .35rem}.sid-row{display:grid;gap:.12rem;margin-bottom:.35rem;padding:.55rem;text-align:left;width:100%}.sid-row:hover,.sid-row.active{background:#eef7f4;border-color:#b9d8d0}.sid-row span{color:#0f766e;font-family:Cascadia Mono,Consolas,monospace;font-size:.78rem;font-weight:800}.sid-row small{color:#66736f;overflow-wrap:anywhere}.uds-main-panel,.uds-side-panel,.sticky-tool-stack{display:grid;gap:1rem}.collapse-trigger{padding:.8rem;text-align:left;width:100%}.collapse-icons{align-items:center;color:#173f3b;display:inline-flex;gap:.35rem}.collapse-body{border-top:1px solid #e5ece8;display:grid;gap:.75rem;padding:.8rem}.collapse-body label{color:#66736f;display:grid;gap:.35rem;font-size:.78rem;font-weight:700;text-transform:uppercase}.active-service-card,.state-machine-panel,.nrc-advisor{background:#f8faf6;border:1px solid #dbe2dd;border-radius:8px;padding:.75rem}.active-service-card span,.precondition-summary span{color:#66736f;display:block;font-size:.72rem;font-weight:700;text-transform:uppercase}.active-service-card p,.precondition-summary p,.nrc-advisor p{color:#4f5f5a;line-height:1.5;margin:.35rem 0 0}.active-service-card dl{display:grid;gap:.45rem;margin:.75rem 0 0}.active-service-card dl div{display:grid;gap:.15rem}.active-service-card dt{color:#66736f;font-size:.72rem}.active-service-card dd{margin:0}.session-state-machine{display:grid;gap:.45rem;grid-template-columns:repeat(3,minmax(0,1fr));margin:.75rem 0}.state-node{background:#fff;border-color:#dbe2dd;padding:.55rem;text-align:left}.state-node.active{background:#ecfdf5;border-color:#86efac}.state-node span{color:#0f766e;font-weight:800}.state-node strong,.state-node small{display:block;min-width:0;overflow-wrap:anywhere;word-break:break-word}.state-node strong{font-size:.92rem;line-height:1.15}.state-node small{color:#66736f}.security-state{align-items:center;background:#fff7ed;border-color:#fed7aa;display:flex;gap:.6rem;padding:.65rem;text-align:left;width:100%}.security-state.unlocked{background:#f0fdf4;border-color:#bbf7d0}.security-state span{color:#66736f;display:block;font-size:.78rem}.path-label{align-items:center;display:flex;gap:.45rem}.nrc-advisor.ok{background:#f0fdf4;border-color:#bbf7d0}.nrc-advisor.bad{background:#fef2f2;border-color:#fecaca}.decision-board{padding-bottom:.85rem}.decision-state{align-items:center;border-radius:999px;display:inline-flex;font-size:.78rem;font-weight:800;gap:.35rem;padding:.3rem .55rem}.decision-state.ok{background:#f0fdf4;color:#15803d}.decision-state.bad{background:#fef2f2;color:#991b1b}.link-pipeline{display:grid;gap:.5rem;grid-template-columns:repeat(5,minmax(120px,1fr));padding:0 .8rem}.decision-step{background:#f8faf6;border:1px solid #dbe2dd;border-radius:8px;min-height:130px;padding:.65rem}.decision-step>span{align-items:center;background:#fff;border:1px solid #dbe2dd;border-radius:999px;display:inline-flex;font-size:.72rem;font-weight:800;height:24px;justify-content:center;width:24px}.decision-step strong{display:block;margin-top:.45rem}.decision-step p{color:#4f5f5a;font-size:.82rem;line-height:1.45;margin:.35rem 0 0}.decision-step.done{border-color:#bbf7d0}.decision-step.active{background:#eef7f4;border-color:#0f766e}.decision-step.error{background:#fef2f2;border-color:#fecaca}.decision-explain{border-radius:8px;margin:.75rem .8rem 0;padding:.75rem}.decision-explain.ok{background:#f0fdf4;border:1px solid #bbf7d0}.decision-explain.bad{background:#fff7ed;border:1px solid #fed7aa}.decision-explain p{color:#4f5f5a;margin:.25rem 0 0}.diagram-sidebar{display:grid;gap:.35rem;padding:0 .8rem .8rem}.diagram-sidebar button{align-items:center;background:#f8faf6;border-color:#dbe2dd;display:flex;gap:.45rem;padding:.5rem;text-align:left}.diagram-sidebar button.active{background:#eef7f4;border-color:#0f766e}.quiz-header{background:#fff;border-radius:8px;padding:.85rem}.quiz-header button{align-items:center;background:#173f3b;color:#fff;display:inline-flex;font-weight:700;gap:.4rem;min-height:38px;padding:.45rem .75rem}.quiz-header button+button{background:#fff;border-color:#cfd9d4;color:#173f3b}.quiz-list{display:grid;gap:.85rem}.quiz-card{border:1px solid #dbe2dd;border-radius:8px;padding:.9rem 1rem}.quiz-card.correct{background:#f0fdf4;border-color:#bbf7d0}.quiz-card.wrong{background:#fef2f2;border-color:#fecaca}.quiz-head{align-items:flex-start;display:flex;gap:.65rem}.quiz-head span{align-items:center;background:#173f3b;border-radius:999px;color:#fff;display:inline-flex;flex:0 0 auto;font-size:.76rem;font-weight:800;height:26px;justify-content:center;width:26px}.quiz-head strong{line-height:1.45}.option-grid{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.7rem}.option{background:#f8faf6;border-color:#dbe2dd;font-weight:650;min-height:36px;padding:.45rem .65rem;text-align:left}.option:hover,.option.active{background:#eef7f4;border-color:#0f766e}.sequence-builder{display:grid;gap:.55rem}.quiz-input{margin-top:.7rem;width:min(360px,100%)}.quiz-explanation{background:#ffffffbf;border:1px solid #dbe2dd;border-radius:8px;color:#34423e;line-height:1.6;margin:.8rem 0 0;padding:.7rem}@media(max-width:1180px){.app-layout,.app-layout.no-panel{grid-template-columns:220px minmax(0,1fr)}.app-layout-right{display:none}.uds-main-grid{grid-template-columns:minmax(0,1fr)}.sid-catalog-rail{max-height:none;position:static}.sid-catalog-scroll{display:grid;gap:.5rem;grid-template-columns:repeat(2,minmax(0,1fr));max-height:none}.link-pipeline{grid-template-columns:repeat(2,minmax(0,1fr))}.home-hero-panel,.module-entry-grid,.path-timeline,.home-reference-grid{grid-template-columns:1fr}}@media(max-width:760px){.app-layout,.app-layout.no-panel{display:block}.app-layout-left{border-bottom:1px solid rgba(236,244,241,.12);border-right:none;max-height:42vh}.workspace-tailwind{padding:.75rem}.topbar-tailwind,.uds-command-strip{grid-template-columns:1fr}.topbar-tailwind{display:grid}.topbar-metrics-tailwind{grid-template-columns:1fr}.home-hero-panel{padding:1rem}.home-hero-copy h2{font-size:1.35rem}.scenario-rail,.sid-catalog-scroll,.session-state-machine,.layer-detail-grid,.link-pipeline{grid-template-columns:1fr}.layer-mode-strip{align-items:stretch;display:grid}.layer-mode-strip button{min-width:0}.quiz-global-progress{flex-basis:100%}}:root{--console-ink: #111817;--console-muted: #5f6b66;--console-subtle: #8a9691;--console-canvas: #f6f8f7;--console-surface: #ffffff;--console-surface-alt: #f9fbfa;--console-line: #dde5e1;--console-line-strong: #b8c6c0;--console-sidebar: #123d39;--console-sidebar-soft: #194a45;--console-focus: rgba(15, 118, 110, .14);--console-shadow: 0 1px 2px rgba(17, 24, 23, .05), 0 12px 28px rgba(17, 24, 23, .07)}body{background:linear-gradient(180deg,#ffffffbd,#f6f8f700 260px),var(--console-canvas);color:var(--console-ink)}code{background:#f3f7f5;border-color:#d8e2dd;border-radius:5px;color:#183f3b;font-family:Cascadia Mono,SFMono-Regular,Consolas,monospace}.app-layout{background:var(--console-canvas)}.app-layout-left{background:linear-gradient(180deg,#ffffff0a,#fff0),var(--console-sidebar);border-right-color:#dde5e16b}.app-layout-right{background:#fbfcfb;border-left-color:var(--console-line)}.knowledge-tree{gap:.35rem;padding:1rem .85rem}.knowledge-tree-brand{margin:0 .15rem .65rem;padding-bottom:1rem}.knowledge-tree-brand strong{font-size:1rem;letter-spacing:0}.tree-section-header,.tree-item{border-radius:7px}.tree-section-header{color:#ecf4f1b8;min-height:34px;padding:.48rem .55rem}.tree-section-header:hover,.tree-item:hover{background:#ffffff14}.tree-section-header.active{background:#ffffff21;color:#fff}.tree-item{color:#ecf4f1d1;min-height:31px;padding:.34rem .55rem}.tree-item.active{background:#ffffff24;color:#fff;box-shadow:inset 3px 0 #ffffffb3}.tree-section-header em,.tree-item em{border:1px solid rgba(255,255,255,.14);border-radius:999px;color:#ecf4f1b8;font-size:.62rem;font-style:normal;font-weight:760;margin-left:auto;padding:.05rem .35rem;white-space:nowrap}.tree-chevron-spacer{width:14px}.workspace-tailwind{padding:1rem 1.2rem 1.6rem}.topbar-tailwind{background:#ffffffdb;border-color:var(--console-line);box-shadow:0 1px #11181708;gap:1.25rem;padding:.78rem .9rem .78rem 1rem}.topbar-title{font-size:1.34rem;font-weight:760}.eyebrow,.eyebrow-tailwind,.panel-label{color:var(--console-muted);font-size:.7rem;font-weight:720;letter-spacing:0}.topbar-metrics-tailwind{gap:.45rem;grid-template-columns:repeat(3,108px)}.topbar-metrics-tailwind div{background:#fbfcfb;border-color:var(--console-line);border-radius:7px;min-height:48px;padding:.52rem .65rem}.topbar-metrics-tailwind strong{font-size:.94rem}.surface,.home-hero-panel,.learning-path-panel,.module-entry,.uds-workspace>.section-heading,.uds-command-strip,.sid-catalog-rail,.trainer-panel,.decision-board,.diagram-gallery,.quiz-card,.quiz-header{background:var(--console-surface);border:1px solid var(--console-line);border-radius:8px}.surface,.quiz-card,.sid-catalog-rail,.trainer-panel,.decision-board,.diagram-gallery{box-shadow:none}.home-hero-panel{box-shadow:var(--console-shadow);min-height:220px}.home-hero-copy h2{font-size:1.64rem;font-weight:760;letter-spacing:0;max-width:760px}.home-hero-copy p,.module-entry p,.path-timeline p,.active-service-card p,.precondition-summary p,.nrc-advisor p,.decision-step p,.decision-explain p{color:var(--console-muted)}.home-status-strip div,.path-timeline article,.active-service-card,.state-machine-panel,.nrc-advisor{background:var(--console-surface-alt);border-color:var(--console-line)}.home-status-strip div.ok,.nrc-advisor.ok,.decision-explain.ok{background:#f0faf6;border-color:#c6eadb}.home-status-strip div.bad,.nrc-advisor.bad,.decision-explain.bad{background:#fff8ed;border-color:#f5d7a8}.module-entry{min-height:172px;padding:.95rem}.module-entry:hover{border-color:var(--console-line-strong);box-shadow:var(--console-shadow)}.module-entry strong{font-size:1.12rem}.module-entry em{color:var(--console-sidebar);font-size:.9rem}.path-timeline article{border-left-color:var(--console-sidebar)}.section-heading h2{font-size:1.05rem;font-weight:720}.section-icon{align-items:center;background:var(--console-surface-alt);border:1px solid var(--console-line);border-radius:7px;color:var(--console-sidebar);display:inline-flex;height:32px;justify-content:center;min-width:32px}button,a,input{-webkit-tap-highlight-color:transparent}button:focus-visible,a:focus-visible,input:focus-visible{box-shadow:0 0 0 3px var(--console-focus);outline:none}.control-row input,.byte-input-grid input,.quiz-input,.sid-search input,.collapse-body input{border-color:#cfdad5;border-radius:7px}.control-row input:focus,.byte-input-grid input:focus,.quiz-input:focus,.sid-search input:focus,.collapse-body input:focus{border-color:#0f766e;box-shadow:0 0 0 3px var(--console-focus)}.frame-bytes{gap:.45rem}.byte-cell{background:#fbfcfb;border-color:var(--console-line);border-radius:7px}.byte-cell:hover,.byte-cell.selected{background:#edf4ff;border-color:#8db8ff}.byte-cell strong,.sid-row span,.footer-lane code{font-family:Cascadia Mono,SFMono-Regular,Consolas,monospace}.byte-input-grid{gap:.55rem}.byte-editor-summary div,.bit-cell{background:#fbfcfb;border-color:var(--console-line);border-radius:7px}.bit-cell.on{background:var(--console-sidebar)}.uds-workspace{gap:.85rem}.uds-workspace>.section-heading{min-height:54px;padding:.85rem 1rem}.uds-command-strip{box-shadow:0 1px #11181708;padding:.65rem .75rem}.view-toggle,.sid-stepper{background:var(--console-surface-alt);border-color:var(--console-line);border-radius:7px}.view-toggle button,.sid-stepper button{border-radius:5px}.view-toggle button.active,.sid-stepper button:hover,.layer-mode-strip button.active{background:var(--console-sidebar)}.layer-mode-strip{gap:.55rem}.layer-mode-strip button,.scenario-rail button,.sid-row,.state-node,.security-state,.diagram-sidebar button,.option{border-color:var(--console-line);border-radius:7px}.layer-mode-strip button{background:#fbfcfb;min-width:205px}.layer-mode-strip button.active{border-color:var(--console-sidebar)}.scenario-rail{gap:.55rem}.scenario-rail button{background:#fbfcfb}.scenario-rail button.active{background:#fff6ea;border-color:#f2b56f;box-shadow:inset 3px 0 0 var(--uds-orange)}.uds-main-grid{grid-template-columns:250px minmax(0,1fr) 300px}.sid-catalog-rail>.panel-title-row,.diagram-gallery>.panel-title-row,.decision-board>.panel-title-row{border-bottom:1px solid var(--console-line);padding:.72rem .78rem}.sid-catalog-scroll{padding:0 .5rem .6rem}.sid-row:hover,.sid-row.active{background:#eef7f4;border-color:#aacfc6}.collapse-trigger{padding:.72rem .78rem}.collapse-body{border-top-color:var(--console-line);padding:.72rem .78rem}.session-state-machine{gap:.45rem}.state-node{background:#fff}.state-node.active{background:#effaf5;border-color:#94ddbd}.security-state{background:#fff7ed}.link-pipeline{gap:.55rem}.decision-step{background:#fbfcfb;border-color:var(--console-line);border-radius:7px}.decision-step.active{background:#eef7f4;border-color:#79bdb1}.decision-step.error{background:#fff1f0;border-color:#f4b9b3}.quiz-header{padding:.78rem .85rem}.quiz-global-progress-bar{background:#e7eeea}.quiz-global-progress-fill{background:linear-gradient(90deg,#123d39,#16825d)}.quiz-header button{background:var(--console-sidebar);border-color:var(--console-sidebar);border-radius:7px}.quiz-header button+button{background:#fff;border-color:#cfdad5}.quiz-list{gap:.78rem}.quiz-card{padding:.82rem .95rem}.quiz-card.correct{background:#f0faf6;border-color:#c6eadb}.quiz-card.wrong{background:#fff1f0;border-color:#f4b9b3}.quiz-head span{background:var(--console-sidebar);height:24px;width:24px}.option{background:#fbfcfb;border-color:#d9e3de;border-radius:7px;font-weight:680}.option:hover,.option.active{background:#eef7f4;border-color:#79bdb1}.quiz-explanation{background:#fbfcfb;border-color:var(--console-line)}.validation-panel article,.panel-section,.stat-row{border-radius:7px}.footer-frame-log{background:#fff;border-top:1px solid var(--console-line)}@media(max-width:1180px){.topbar-metrics-tailwind{grid-template-columns:repeat(3,minmax(96px,1fr))}}@media(max-width:760px){.knowledge-tree{padding:.72rem}.topbar-title{font-size:1.18rem}.home-hero-panel{min-height:0}.module-entry{min-height:148px}.frame-bytes,.byte-input-grid,.bit-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.sketch-board{background:linear-gradient(180deg,#fffffff2,#f9fbfaf2),radial-gradient(circle at top left,rgba(24,226,153,.08),transparent 38%);border:1px solid rgba(0,0,0,.08);border-radius:10px;box-shadow:#00000014 0 0 0 1px,#0000000a 0 2px 2px,#0000000a 0 12px 18px -16px;gap:.85rem}.sketch-board:after{display:none}.sketch-title{align-items:center}.sketch-title>svg{background:#f1f7f4;border:1px solid rgba(0,0,0,.08);border-radius:8px;box-shadow:#0000000a 0 1px 2px;color:var(--console-sidebar, #123d39)}.sketch-title span{color:var(--console-muted, #5f6b66);font-size:.72rem;font-weight:720;text-transform:uppercase}.sketch-title h3{font-size:1rem;font-weight:720}.sketch-chain article,.can-visual,.timeline-card,.uds-message-grid article{background:#ffffffdb;border:1px solid rgba(0,0,0,.08);border-radius:9px;box-shadow:none}.sketch-byte{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:8px;min-height:82px}.sketch-byte:before{opacity:.45}.sketch-byte span,.sketch-byte small{color:var(--console-muted, #5f6b66)}.sketch-byte strong{font-family:Geist Mono,Cascadia Mono,SFMono-Regular,Consolas,monospace;font-size:1rem}.sketch-byte.teal{background:#edf7f4;border-color:#cfe5de}.sketch-byte.amber{background:#fff7e6;border-color:#f4dfb7}.sketch-byte.blue{background:#edf4ff;border-color:#cfe0fb}.sketch-byte.green{background:#effaf5;border-color:#c8ebdc}.sketch-byte.red{background:#fff1f0;border-color:#f4c9c3}.bus-line strong{border-bottom:3px solid var(--console-sidebar, #123d39);color:var(--console-sidebar, #123d39)}.bus-line span,.swimlane-heads span{background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:999px;box-shadow:#00000008 0 1px 2px}.sketch-notes p{background:#fffaf0;border:1px solid #f0d9aa;border-radius:8px}.service-overview-card{background:#ffffffc7;border:1px solid rgba(0,0,0,.08);border-radius:9px}.response-rule-card{background:#effaf5;border-color:#c8ebdc;border-radius:8px}.swimlane-step{background:#ffffffe6;border:1px solid rgba(0,0,0,.12);border-radius:8px}.swimlane-step:hover{box-shadow:#00000014 0 2px 8px}.swimlane-step.active{box-shadow:0 0 0 2px #123d3938}.sequence-index,.mini-flow-node span{background:var(--console-sidebar, #123d39)}.service-step-inspector,.payload-hint-card,.beginner-traps p,.field-footnote,.layer-detail-card,.can-frame-lab article,.nrc-focus-card,.state-check-card{border-radius:9px}.isotp-lanes,.isotp-lanes.single{align-items:start;background:#fbfcfb;border:1px solid rgba(0,0,0,.06);border-radius:10px;grid-template-columns:120px minmax(260px,1fr) 120px;padding:.75rem}.isotp-lanes:not(.single){grid-template-columns:110px repeat(3,minmax(180px,1fr)) 110px}.isotp-lanes.single .timeline-card{grid-column:2}.isotp-lanes:not(.single) .timeline-card.ff{grid-column:2}.isotp-lanes:not(.single) .timeline-card.fc{grid-column:3}.isotp-lanes:not(.single) .timeline-card.cf{grid-column:4}.timeline-card{min-height:180px}.timeline-card:before,.timeline-card:after{content:none}.timeline-card code{align-self:start;display:block;line-height:1.45;white-space:normal}.timeline-card p{max-width:32ch}.decision-strip{background:#fbfcfb;border:1px solid rgba(0,0,0,.06);border-radius:8px;padding:.5rem}@media(max-width:760px){.home-next-steps{grid-template-columns:1fr}.isotp-lanes,.isotp-lanes.single,.isotp-lanes:not(.single){grid-template-columns:1fr}.lane-label.tester,.lane-label.ecu,.isotp-lanes.single .timeline-card,.isotp-lanes:not(.single) .timeline-card.ff,.isotp-lanes:not(.single) .timeline-card.fc,.isotp-lanes:not(.single) .timeline-card.cf{grid-column:1}}.isotp-console{display:grid;gap:1rem}.isotp-hero,.isotp-input-card,.isotp-rule-panel{background:var(--console-surface, #ffffff);border:1px solid var(--console-line, #dde5e1);border-radius:10px;box-shadow:#00000014 0 0 0 1px,#0000000a 0 2px 2px}.isotp-hero{align-items:flex-start;display:flex;justify-content:space-between;gap:1rem;padding:1rem}.isotp-hero h2{font-size:1.12rem;line-height:1.25;margin:.15rem 0 0}.isotp-hero p{color:var(--console-muted, #5f6b66);line-height:1.55;margin:.45rem 0 0;max-width:820px}.isotp-icon{color:var(--isotp-purple)}.isotp-summary-grid{display:grid;gap:.75rem;grid-template-columns:repeat(3,minmax(0,1fr))}.isotp-summary-grid article{align-items:start;background:#fff;border:1px solid var(--console-line, #dde5e1);border-radius:10px;display:grid;gap:.28rem;min-height:118px;padding:.85rem}.isotp-summary-grid svg{color:var(--isotp-purple)}.isotp-summary-grid span,.isotp-input-card label,.isotp-rule-panel .panel-title-row span{color:var(--console-muted, #5f6b66);font-size:.72rem;font-weight:760;text-transform:uppercase}.isotp-summary-grid strong{font-size:1.06rem}.isotp-summary-grid small{color:var(--console-muted, #5f6b66);line-height:1.4;overflow-wrap:anywhere}.isotp-workbench{align-items:stretch;display:grid;gap:1rem;grid-template-columns:minmax(360px,.9fr) minmax(360px,1.1fr)}.isotp-input-card,.isotp-rule-panel{display:grid;gap:.85rem;padding:.95rem}.isotp-input-card label{display:grid;gap:.4rem}.isotp-input-card textarea{background:#fbfcfb;border:1px solid #cfdad5;border-radius:8px;color:var(--console-ink, #111817);font-family:Geist Mono,Cascadia Mono,Consolas,monospace;min-height:104px;padding:.7rem .8rem;resize:vertical}.transport-controls{display:grid;gap:.65rem;grid-template-columns:repeat(2,minmax(0,1fr))}.transport-controls input{background:#fbfcfb;border:1px solid #cfdad5;border-radius:8px;min-height:38px;padding:.45rem .6rem}.isotp-rule-strip{display:grid;gap:.55rem;grid-template-columns:repeat(2,minmax(0,1fr))}.isotp-rule-strip article{background:#fbfcfb;border:1px solid var(--console-line, #dde5e1);border-radius:8px;display:grid;gap:.28rem;min-height:86px;padding:.7rem}.isotp-rule-strip article.active{background:#f4efff;border-color:#d8c8ff;box-shadow:inset 3px 0 0 var(--isotp-purple)}.isotp-rule-strip strong{color:var(--isotp-purple);font-family:Geist Mono,Cascadia Mono,Consolas,monospace}.isotp-rule-strip span{color:var(--console-muted, #5f6b66);line-height:1.45}.scenario-row{display:flex;flex-wrap:wrap;gap:.45rem}.scenario-row button{background:#fff;border:1px solid #d8e2dd;border-radius:999px;color:var(--console-ink, #111817);font-weight:650;min-height:34px;padding:.35rem .7rem}.scenario-row button.active,.scenario-row button:hover{background:#f4efff;border-color:#d8c8ff;color:#5b21b6}.frame-list{display:grid;gap:.75rem}.frame-row{background:#fff;border:1px solid var(--console-line, #dde5e1);border-radius:10px;display:grid;gap:.65rem;padding:.85rem}.frame-row-head{align-items:center;display:flex;gap:.55rem}.frame-row-head span{align-items:center;background:var(--isotp-purple);border-radius:999px;color:#fff;display:inline-flex;font-size:.72rem;font-weight:800;height:24px;justify-content:center;width:24px}.frame-row p{color:var(--console-muted, #5f6b66);line-height:1.5;margin:0}.inline-warning{align-items:center;color:var(--error-red)!important;display:flex;gap:.35rem}@media(max-width:1180px){.isotp-workbench,.isotp-summary-grid{grid-template-columns:1fr}}@media(max-width:760px){.isotp-hero{display:grid}.transport-controls,.isotp-rule-strip{grid-template-columns:1fr}}@media(max-width:1180px){.uds-main-grid{grid-template-columns:minmax(0,1fr)}.sid-catalog-rail{max-height:none;position:static}.sid-catalog-scroll{display:grid;gap:.5rem;grid-template-columns:repeat(2,minmax(0,1fr));max-height:none}.uds-main-panel,.uds-side-panel,.decision-board,.sketch-board{min-width:0}.link-pipeline{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.uds-command-strip{grid-template-columns:1fr}.layer-mode-strip,.scenario-rail{display:grid;grid-template-columns:1fr;overflow-x:visible}.layer-mode-strip button,.scenario-rail button{min-width:0}.sid-catalog-scroll,.session-state-machine,.link-pipeline,.swimlane-grid{grid-template-columns:1fr}.swimlane-heads{grid-template-columns:1fr 1fr}.swimlane-lifeline{display:none}.swimlane-step,.swimlane-step.tester,.swimlane-step.ecu,.swimlane-step.internal{grid-column:1;margin-left:0;margin-right:0;width:auto}.decision-step{min-height:auto}.panel-title-row{align-items:flex-start}}
