:root{color:#152017;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f3f7f1;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{margin:0}#root{min-height:100svh}.app{min-height:100svh;padding:24px 18px}.python-test{width:min(1180px,100%);margin:0 auto}.site-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.brand-logo{object-fit:contain;width:auto;max-width:min(220px,42vw);height:44px;display:block}.header-controls{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.task-tabs,.mode-tabs{background:#fff;border:1px solid #c8d5c8;border-radius:8px;gap:4px;padding:4px;display:inline-flex}.task-tab,.mode-tab{color:#4b5a4e;background:0 0;border-radius:6px;padding:7px 12px}.mode-tab{min-width:68px}.task-tab:hover,.task-tab:focus-visible,.mode-tab:hover,.mode-tab:focus-visible{color:#152017;background:#edf5ea}.task-tab-active,.task-tab-active:hover,.task-tab-active:focus-visible,.mode-tab-active,.mode-tab-active:hover,.mode-tab-active:focus-visible{color:#fff;background:#245b37}.learning-intro{max-width:680px;margin-bottom:22px}.learning-intro p:last-child{color:#4b5a4e;margin:8px 0 0;font-size:1.05rem;line-height:1.5}.learning-topbar{grid-template-columns:minmax(220px,1fr) auto;align-items:end;gap:16px;margin-bottom:14px;display:grid}.intro{margin-bottom:0}.eyebrow{color:#4f7d5a;text-transform:uppercase;margin:0 0 4px;font-size:.75rem;font-weight:700}h1,h2{color:#152017;margin:0}h1{font-size:2rem;line-height:1.1}.top-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px 14px;display:flex}.actions{align-items:center;gap:10px;margin:0;display:flex}button{color:#fff;cursor:pointer;font:inherit;background:#245b37;border:0;border-radius:6px;padding:8px 14px;font-weight:700}button:disabled{cursor:not-allowed;opacity:.7}.actions span{color:#4b5a4e}.kodesteg-workspace{grid-template-columns:minmax(0,1.45fr) minmax(430px,1fr);align-items:stretch;gap:24px;display:grid}.practice-workspace{grid-template-columns:minmax(0,1.2fr) minmax(340px,.8fr);align-items:start;gap:24px;display:grid}.practice-side{gap:12px;min-width:0;display:grid}.practice-card{background:#fff;border:1px solid #c8d5c8;border-radius:8px;gap:10px;padding:14px;display:grid}.practice-card h2,.practice-card p{margin:0}.practice-card h2{font-size:1.1rem}.practice-card p{line-height:1.55}.practice-muted{color:#4b5a4e}.feedback-box{color:#152017;background:#fbfdf9;border:1px solid #c8d5c8;border-left:4px solid #4b5a4e;border-radius:8px;padding:12px;font-weight:700}.feedback-box-success{background:#f0faed;border-color:#9fca94 #9fca94 #9fca94 #4caf50}.feedback-box-warning{background:#fff7ea;border-color:#e0b57a #e0b57a #e0b57a #b45f06}.practice-result{gap:10px;display:grid}.practice-result-grid{gap:6px}.practice-result-grid p{grid-template-columns:minmax(140px,1fr) auto;align-items:baseline;gap:12px;display:grid}.practice-result-grid span{color:#4b5a4e;font:700 .9rem/1.35 Inter,ui-sans-serif,system-ui,sans-serif}.code-panel{grid-template-rows:auto 1fr;gap:12px;min-width:0;display:grid}.code-toolbar{justify-content:space-between;align-items:center;gap:12px;display:flex}.code-toolbar .step-controls{flex-wrap:wrap;justify-content:flex-end}.editor{color:#26352a;grid-template-rows:auto 1fr;gap:6px;min-width:0;font-weight:700;display:grid}textarea,pre{box-sizing:border-box;color:#152017;background:#fbfdf9;border:1px solid #c8d5c8;border-radius:8px;width:100%;font:1rem/1.55 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}textarea{resize:vertical;min-height:180px;padding:16px}textarea:focus{border-color:#4f7d5a;outline:3px solid #4f7d5a2e}.editor-code-window{height:calc(var(--editor-line-count,1) * 1.45rem + 24px);background:#1e1e1e;border:1px solid #30363d;border-radius:8px;min-height:calc(1.45rem + 24px);max-height:42svh;position:relative;overflow:hidden}.kodesteg-workspace .editor-code-window{height:clamp(520px,100svh - 255px,760px);min-height:520px;max-height:none}.practice-workspace .editor-code-window{height:clamp(360px,100svh - 320px,620px);min-height:360px;max-height:none}.editor-code-window:focus-within{border-color:#4f7d5a;outline:3px solid #4f7d5a3d}.editor-code-preview,.editor-textarea{box-sizing:border-box;font:.95rem/1.45 JetBrains Mono,Fira Code,monospace}.editor-code-preview{color:#d4d4d4;pointer-events:none;white-space:pre;padding:12px 0;position:absolute;inset:0}.editor-code-line{box-sizing:border-box;border-left:3px solid #0000;grid-template-columns:44px 1fr;min-height:1.45rem;display:grid}.editor-code-line-active{color:#d4d4d4;background:#2a2d2e;border-left-color:#4caf50}.editor-line-number{color:#6e7681;text-align:right;-webkit-user-select:none;user-select:none;padding-right:10px}.editor-code-line-active .editor-line-number{color:#6e7681;font-weight:800}.editor-line-content{padding-left:12px}.editor-code-line-active .editor-line-content{font-weight:800}.syntax-keyword{color:#c586c0}.syntax-function{color:#dcdcaa}.syntax-number{color:#b5cea8}.syntax-variable,.syntax-operator{color:#d4d4d4}.editor-textarea{caret-color:#d4d4d4;color:#0000;resize:none;background:0 0;border:0;height:100%;min-height:100%;padding:12px 14px 12px 58px;position:absolute;inset:0;overflow:hidden}.editor-textarea::selection{background:#74977c52}.editor-textarea:focus{border:0;outline:0}.info-panel{align-content:start;gap:10px;min-width:0;display:grid}.info-panel>h2{color:#4b5a4e;font-size:1rem;font-weight:700}.accordion-list{gap:8px;display:grid}.accordion-section{background:#ffffff9e;border:1px solid #0000;border-left-width:4px;border-radius:8px;overflow:hidden}.accordion-section-open{background:#fff;border-color:#c8d5c8 #c8d5c8 #c8d5c8 #4caf50;box-shadow:0 10px 24px #245b3714}.accordion-trigger{color:#152017;text-align:left;background:0 0;border-radius:0;grid-template-columns:28px 1fr 20px;align-items:center;gap:10px;width:100%;padding:12px 14px 12px 12px;display:grid}.accordion-trigger:hover,.accordion-trigger:focus-visible{background:#edf5ea}.accordion-icon{color:#245b37;background:#edf5ea;border-radius:6px;place-items:center;width:24px;height:24px;font-size:.78rem;font-weight:800;display:grid}.accordion-arrow{color:#4b5a4e;transition:transform .18s;transform:rotate(0)}.accordion-section-open .accordion-arrow{transform:rotate(90deg)}.accordion-content{grid-template-rows:0fr;transition:grid-template-rows .18s;display:grid}.accordion-section-open .accordion-content{grid-template-rows:1fr}.accordion-content-inner{min-height:0;overflow:hidden}.accordion-section-open .accordion-content-inner{border-top:1px solid #edf2ea}.observation-summary{gap:8px;padding:10px 12px;display:grid}.observation-block{gap:5px;display:grid}.observation-block h3,.compact-variable-list h3{color:#4b5a4e;letter-spacing:0;text-transform:uppercase;margin:0;font-size:.78rem}.runtime-card,.runtime-data-section{background:#fff;border:1px solid #c8d5c8;border-radius:8px;gap:8px;padding:10px;display:grid}.runtime-card h2,.runtime-card h3,.runtime-data-section h2{font-size:.95rem}.accordion-content .runtime-card,.accordion-content .runtime-data-section{background:0 0;border:0;border-radius:0;padding:14px}.runtime-card-empty{color:#4b5a4e;margin:0;line-height:1.55}.runtime-expression{color:#152017;white-space:pre-wrap;background:#f6fbf4;border:1px solid #c8d5c8;border-radius:8px;margin:0;padding:14px 16px;font:1.35rem/1.35 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.observation-block .runtime-expression{border-radius:6px;padding:7px 10px}.runtime-observation{color:#152017;margin:0;font-size:1.03rem;line-height:1.48}.observation-note{color:#245b37;margin:0;font-weight:700;line-height:1.55}.runtime-loop-info{color:#152017;background:0 0;border:0;border-radius:0;gap:2px;padding:0;display:grid}.runtime-loop-info p{margin:0}.runtime-loop-info p:last-child{font:.95rem/1.45 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.runtime-print-output{color:#152017;white-space:pre-wrap;background:#fbfdf9;border:1px solid #c8d5c8;border-radius:8px;min-height:56px;max-height:112px;margin:0;padding:8px 10px;font:.9rem/1.4 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;overflow:auto}.compact-variable-list{color:#152017;gap:7px;display:grid}.compact-variable-row{color:#152017;margin:0;font:1rem/1.35 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.compact-variable-row-changed{color:#245b37;font-weight:800}.result-box{color:#152017;background:#f0faed;border:1px solid #9fca94;border-left:4px solid #4caf50;border-radius:8px;gap:8px;padding:12px;display:grid}.result-box h3,.result-box p{margin:0}.result-box h3{color:#245b37;text-transform:uppercase;font-size:.85rem}.result-estimate{gap:2px;font:800 1rem/1.4 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;display:grid}.figurtall-result-box{gap:10px}.figurtall-result-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.figurtall-result-item{background:#fbfdf9;border:1px solid #c8d5c8;border-radius:8px;padding:10px}.figurtall-result-label{color:#4b5a4e;text-transform:uppercase;font-size:.82rem;font-weight:800}.figurtall-result-value{color:#152017;margin-top:4px;font:900 1.55rem/1.2 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.runtime-variable-list{background:#fbfdf9;border:1px solid #c8d5c8;border-radius:8px;display:grid;overflow:hidden}.runtime-variable-row{color:#152017;border-bottom:1px solid #c8d5c8;grid-template-columns:minmax(70px,1fr) minmax(72px,1fr);gap:10px;padding:7px 10px;font:.9rem/1.4 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;display:grid}.runtime-variable-row:last-child{border-bottom:0}.runtime-variable-row span:first-child{color:#4b5a4e;font-weight:700}.runtime-variable-row-changed{background:#edf5ea}.runtime-variable-row-changed span:first-child{color:#245b37}.runtime-variable-row-changed span:last-child{font-weight:700}.step-controls{align-items:center;gap:12px;display:flex}.step-controls-top{justify-content:flex-end}.step-count{color:#4b5a4e;white-space:nowrap;font-weight:700}.runtime-table-section,.runtime-graph-section{grid-column:auto}.visualization-section{gap:12px}.visualization-grid{grid-template-columns:minmax(0,2.1fr) minmax(130px,.9fr);align-items:start;gap:12px;display:grid}.visualization-grid-figurtall{grid-template-columns:minmax(170px,.82fr) minmax(0,1.45fr);align-items:stretch}.visualization-table-panel,.visualization-graph-panel{min-width:0}.visualization-grid-figurtall .visualization-table-panel,.visualization-grid-figurtall .visualization-graph-panel{display:grid}.visualization-graph-panel{order:-1}.runtime-table{border-collapse:collapse;color:#152017;background:#fbfdf9;border:1px solid #c8d5c8;width:100%}.runtime-table th,.runtime-table td{text-align:left;border-bottom:1px solid #c8d5c8;padding:7px 10px}.runtime-table th{color:#26352a;background:#edf5ea}.runtime-table tr:last-child td{border-bottom:0}.runtime-table-active-row td{background:#dff4d8}.runtime-table-active-row td:first-child{border-left:3px solid #4caf50}.runtime-graph{background:#fbfdf9;border:0;width:100%;height:clamp(220px,34svh,320px)}.accordion-section-open .runtime-graph{height:clamp(320px,52svh,520px)}.accordion-section-open .visualization-grid .runtime-graph{height:clamp(300px,36svh,340px)}.compact-point-list{color:#26352a;gap:2px;width:100%;min-width:0;font:.74rem/1.25 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;display:grid}.visualization-grid-figurtall .compact-point-list{background:#fbfdf9;border:1px solid #c8d5c8;border-radius:8px;align-content:start;padding:8px;font-size:.82rem;line-height:1.35}.compact-point-row{white-space:nowrap;border-radius:4px;grid-template-columns:1ch minmax(4.2ch,1fr) minmax(5ch,1fr) minmax(4ch,1fr);align-items:center;column-gap:5px;min-width:0;padding:2px 3px;display:grid}.compact-point-row-figurtall{font-size:inherit;grid-template-columns:1ch minmax(2.6ch,.42fr) minmax(3.2ch,.5fr) minmax(3.2ch,.5fr) minmax(5.6ch,.82fr) minmax(5.6ch,.82fr);column-gap:6px;padding:3px 4px}.compact-point-row span{text-overflow:clip;overflow:hidden}.compact-point-header{color:#4b5a4e;font-weight:800}.compact-point-row-active{color:#152017;background:#dff4d8;font-weight:800}.figurtall-figure{color:#152017;background:#fbfdf9;border:1px solid #c8d5c8;border-radius:8px;align-content:start;gap:12px;padding:12px;display:grid}.figurtall-figure-header{gap:8px;display:grid}.figurtall-figure-header p,.figurtall-note{margin:0}.figurtall-figure-header p{color:#245b37;font-weight:800}.figurtall-figure-header div{flex-wrap:wrap;gap:8px;display:flex}.figurtall-figure-header span{color:#26352a;background:#fff;border:1px solid #c8d5c8;border-radius:6px;padding:5px 8px;font:800 .86rem/1.35 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.figurtall-pattern{gap:12px;display:grid}.figurtall-pins{flex-wrap:wrap;align-items:center;gap:5px;min-height:22px;display:flex}.figurtall-pins span{background:#8a5a2b;border-radius:999px;width:28px;height:5px;display:block}.figurtall-dots{grid-template-columns:repeat(var(--figur-kolonner), 18px);align-items:center;gap:8px;min-height:28px;display:grid}.figurtall-dots span:not(.figurtall-empty){background:#dff4d8;border:2px solid #245b37;border-radius:50%;width:18px;height:18px;display:block}.figurtall-empty{color:#4b5a4e;font-weight:700}.figurtall-note{color:#4b5a4e;font-size:.88rem;line-height:1.45}.math-section{color:#26352a;line-height:1.55}.math-section p{margin:0}.runtime-graph line{stroke:#9cad9b;stroke-width:1px}.runtime-graph-axis{stroke:#6b7b6e;stroke-width:1.5px}.runtime-graph-tick{stroke:#6b7b6e}.runtime-graph-curve{fill:none;stroke:#5b6f8f;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px}.runtime-graph-points-line{fill:none;stroke:#245b37;stroke-linecap:round;stroke-linejoin:round;stroke-width:3px}.runtime-graph circle{fill:#245b37}.runtime-graph text{fill:#4b5a4e;font:.75rem Inter,ui-sans-serif,system-ui,sans-serif}.runtime-graph-axis-label{fill:#26352a;text-anchor:middle;font-size:.85rem;font-weight:700}.runtime-graph-axis-number{text-anchor:middle}.runtime-graph-y-number{dominant-baseline:middle;text-anchor:end}.runtime-graph-active-point{fill:#4caf50;stroke:#245b37;stroke-width:3px}.runtime-graph-expression{color:#152017;margin:0;font:700 .95rem/1.4 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.graph-estimate-summary{color:#152017;background:#f0faed;border:1px solid #9fca94;border-radius:8px;gap:2px;padding:8px 10px;font:.9rem/1.35 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;display:grid}.graph-estimate-summary p{margin:0}.graph-estimate-summary p:first-child{color:#245b37;font-weight:800}.runtime-graph-estimate line{stroke:#b45f06;stroke-dasharray:5 4;stroke-width:1.5px}.runtime-graph-estimate circle{fill:#f2a23a;stroke:#8a4303;stroke-width:3px}.runtime-graph-estimate text{fill:#8a4303;text-anchor:middle;font-weight:800}pre{white-space:pre-wrap;margin:0;overflow-x:auto}@media (width<=1000px){.learning-topbar{grid-template-columns:1fr}.top-actions,.step-controls-top{justify-content:flex-start}.kodesteg-workspace,.practice-workspace{grid-template-columns:1fr}.code-toolbar,.code-toolbar .step-controls{justify-content:flex-start}.kodesteg-workspace .editor-code-window{height:clamp(420px,62svh,640px);min-height:420px}.practice-workspace .editor-code-window{height:clamp(340px,54svh,520px);min-height:340px}}@media (width<=820px){.runtime-table-section,.runtime-graph-section{grid-column:1}.visualization-grid{grid-template-columns:1fr}}@media (width<=640px){.app{padding:18px 14px}.site-header{flex-direction:column;align-items:flex-start}.brand-logo{max-width:min(190px,70vw);height:36px}.header-controls,.task-tabs,.mode-tabs{width:100%}.task-tabs,.mode-tabs{flex-wrap:wrap}h1{font-size:1.7rem}.code-toolbar,.step-controls{flex-direction:column;align-items:stretch}.kodesteg-workspace .editor-code-window{height:380px;min-height:380px}.practice-workspace .editor-code-window{height:340px;min-height:340px}}
