.runner-root{--bg-primary: #f8f6f3;--bg-secondary: #f0ede8;--border-color: #c8c4bd;--text-primary: #1a1a1a;--text-muted: #7a746c;--ink-blue: #1e3a8a;--accent-blue: #2563eb;--ink-green: #047857;--accent-green: #059669;--ink-red: #b91c1c;--accent-red: #dc2626;--ink-purple: #6b21a8;--accent-purple: #7c3aed;--ink-orange: #d97706;--accent-orange: #f59e0b;--space: 8px;--radius: 8px;--font-size: 13px;--font-mono: "Monaco", "Menlo", "Ubuntu Mono", monospace;--shadow: 0 2px 6px rgba(0, 0, 0, .1);--shadow-strong: 0 4px 12px rgba(0, 0, 0, .15)}.runner-root{background:var(--bg-primary);border-radius:calc(var(--radius) / 2)}.runner-root .toolbar{gap:calc(var(--space) / 2);padding:calc(var(--space) / 2);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:calc(var(--radius) / 2);box-shadow:var(--shadow);margin-bottom:calc(var(--space) / 2)}.runner-root .toolbar input[type=range]{background:var(--bg-primary);border-radius:calc(var(--radius) / 2);height:calc(var(--space) / 3);border:1px solid var(--border-color)}.runner-root .toolbar input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:calc(var(--space) * 1.2);height:calc(var(--space) * 1.2);border-radius:50%;background:linear-gradient(145deg,var(--ink-blue) 0%,var(--accent-blue) 100%);cursor:pointer;box-shadow:var(--shadow);border:1px solid var(--bg-primary);transition:all .2s ease}.runner-root .editor-container,.runner-root .debug-bar,.runner-root .test-bar,.runner-root .stack-frame{background:var(--bg-primary);border-radius:var(--radius);border:1px solid var(--border-color);box-shadow:var(--shadow)}.runner-root .debug-bar,.runner-root .test-bar{width:240px;padding:var(--space);background:var(--bg-secondary);animation:fadeIn .3s ease-out}.runner-root .console-output{color:var(--text-primary);padding:0;border-radius:var(--radius);font-family:var(--font-mono);font-size:var(--font-size);animation:fadeIn .3s ease-out}.runner-root .console-input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);padding:calc(var(--space) / 2);margin-top:calc(var(--space) / 2);box-shadow:var(--shadow);gap:calc(var(--space) / 2);animation:fadeIn .3s ease-out}.runner-root .console-input input[type=text]{padding:calc(var(--space) / 2) var(--space);border:1px solid var(--accent-red);border-radius:calc(var(--radius) / 2);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:var(--font-size);transition:all .2s ease;flex:1}.runner-root .console-input input[type=text]:focus{outline:none;border-color:var(--ink-blue);box-shadow:0 0 0 2px #2563eb26}.runner-root .console-input input[type=text]::placeholder{color:var(--accent-red);font-style:italic}.runner-root .console-output span.hl{background-color:#fc03;color:var(--text-primary);border-radius:4px;padding:0 2px}.runner-root .stack-frame{margin-bottom:var(--space);transition:all .2s ease;animation:slideIn .3s ease-out}.runner-root .stack-frame:hover{box-shadow:var(--shadow-strong);border-color:var(--ink-blue)}.runner-root .frame-header{background:var(--bg-secondary);padding:var(--space);border-bottom:1px solid var(--border-color)}.runner-root .function-name,.runner-root .variable-name{color:var(--ink-blue);font-family:var(--font-mono);font-weight:700;font-size:var(--font-size)}.runner-root .line-number{color:var(--ink-orange);font-family:var(--font-mono);font-size:calc(var(--font-size) - 1px);background:var(--bg-secondary);padding:calc(var(--space) / 2);border-radius:var(--radius);border:1px solid var(--border-color);font-weight:600;box-shadow:var(--shadow)}.runner-root .frame-body{padding:var(--space)}.runner-root .variable-entry{background:var(--bg-secondary);color:var(--text-primary);padding:calc(var(--space) / 2) var(--space);margin:2px 0;border-radius:var(--radius);border:1px solid var(--border-color);gap:var(--space);transition:all .2s ease}.runner-root .variable-name{color:var(--ink-purple)}.runner-root .variable-value{color:var(--ink-green);font-family:var(--font-mono);font-size:var(--font-size);font-weight:600}.runner-root .hl-currentline{background-color:#05966926}.runner-root .hl-currentline-glyph:before{content:"▶";color:var(--ink-green);font-size:var(--font-size)}.runner-root .hl-error{background-color:#dc262626}.runner-root .hl-error-glyph:before{content:"✖";color:var(--ink-red);font-size:var(--font-size)}.runner-root span.stdin{color:var(--ink-purple)}.runner-root span.exception{color:var(--ink-red)}.runner-root span.test-OK{background-color:#31b35180}.runner-root span.test-WF{background-color:#ccba1880}.runner-root span.test-WA{background-color:#96160580}.runner-root span.test-MA{background-color:#96057780}.runner-root span.test-RE{background-color:#2933c080}.runner-root button{background:linear-gradient(145deg,var(--text-muted) 0%,var(--text-primary) 100%);border:1px solid var(--text-muted);color:var(--bg-primary);border-radius:calc(var(--radius) / 2);padding:calc(var(--space) / 2) calc(var(--space) / 1.5);gap:calc(var(--space) / 2);font-weight:600;font-size:calc(var(--font-size) - 1px);transition:all .2s ease;box-shadow:var(--shadow)}.runner-root button:hover:not(:disabled){border-color:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-strong)}.runner-root button:disabled{opacity:.5;cursor:not-allowed}.runner-root button.green{background:linear-gradient(145deg,var(--accent-green) 0%,var(--ink-green) 100%);border-color:var(--ink-green)}.runner-root button.blue{background:linear-gradient(145deg,var(--accent-blue) 0%,var(--ink-blue) 100%);border-color:var(--ink-blue)}.runner-root button.red{background:linear-gradient(145deg,var(--accent-red) 0%,var(--ink-red) 100%);border-color:var(--ink-red)}.runner-root button.file-tab{border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:6px}.runner-root button.file-tab:hover{background:#0000000a;color:var(--text-primary)}.runner-root button.file-tab.hl{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color)}.runner-root button.test-selector{background:linear-gradient(145deg,var(--text-muted) 0%,var(--text-primary) 100%);border:1px solid var(--text-muted);color:var(--bg-primary);border-radius:calc(var(--radius) / 2);padding:calc(var(--space) / 2) var(--space);font-weight:600;font-size:calc(var(--font-size) - 1px);transition:all .2s ease;box-shadow:var(--shadow);min-width:32px;text-align:center}.runner-root div.result-type-info{margin:0;padding:calc(var(--space) / 2) var(--space);display:flex;align-items:center;justify-content:center;border-radius:calc(var(--radius) / 2);color:var(--bg-primary);font-weight:600;font-size:calc(var(--font-size) - 1px);flex:1;min-height:100%}.runner-root div.test-OK,.runner-root button.test-OK{background:linear-gradient(145deg,var(--accent-green) 0%,var(--ink-green) 100%);border-color:var(--ink-green)}.runner-root div.test-WA,.runner-root button.test-WA{background:linear-gradient(145deg,var(--accent-red) 0%,var(--ink-red) 100%);border-color:var(--ink-red)}.runner-root div.test-RE,.runner-root button.test-RE{background:linear-gradient(145deg,var(--accent-blue) 0%,var(--ink-blue) 100%);border-color:var(--ink-blue)}.runner-root div.test-MA,.runner-root button.test-MA{background:linear-gradient(145deg,var(--accent-purple) 0%,var(--ink-purple) 100%);border-color:var(--ink-purple)}.runner-root div.test-WF,.runner-root button.test-WF{background:linear-gradient(145deg,var(--accent-orange) 0%,var(--ink-orange) 100%);border-color:var(--ink-orange)}.runner-root button.test-selector.hl{background:var(--bg-secondary);border:1px solid var(--ink-blue);color:var(--text-primary);box-shadow:var(--shadow);font-weight:700}.runner-root button.test-selector.hl:hover{transform:none}.runner-root .inspect-panel{animation:fadeIn .3s ease-out}.runner-root .test-summary{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);padding:var(--space);margin-top:calc(var(--space) / 2);box-shadow:var(--shadow);color:var(--text-primary);animation:fadeIn .3s ease-out}.runner-root .test-summary h2{font-family:var(--font-mono);font-size:calc(var(--font-size) + 4px);font-weight:700;color:var(--ink-blue);margin:0 0 var(--space) 0;padding:calc(var(--space) / 2) var(--space);background:var(--bg-secondary);border-radius:calc(var(--radius) / 2);border:1px solid var(--border-color);text-align:center;box-shadow:var(--shadow)}.runner-root .test-summary-table{width:100%;border-collapse:separate;border-spacing:0;font-family:var(--font-mono);font-size:var(--font-size);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:calc(var(--radius) / 2);overflow:hidden;box-shadow:var(--shadow)}.runner-root .test-summary-table tr:nth-child(2n){background:var(--bg-secondary)}.runner-root .test-summary-table td{padding:calc(var(--space) / 2) var(--space);border-bottom:1px solid var(--bg-secondary);transition:all .2s ease}.runner-root .test-summary-table tr:last-child td{border-bottom:none}.runner-root tr.test-table-header td{background-color:var(--border-color);font-weight:700;color:var(--text-primary)}.runner-root .test-name{color:var(--ink-purple);font-weight:600;text-align:left;border-right:1px solid var(--bg-secondary)}.runner-root .test-score{color:var(--ink-green);font-weight:700;text-align:right;min-width:60px}.runner-root .test-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:calc(var(--space) / 2);gap:calc(var(--space) / 2)}.module-root .page-body{--paper-white: #ffffff;--paper-beige: #eeeae2;--paper-gray: #c8c4bd;--paper-dark-gray: #7a746c;--ink-black: #1a1a1a;--ink-blue: #1e3a8a;--ink-green: #047857;--ink-red: #b91c1c;--ink-purple: #6b21a8;--ink-orange: #c2410c;--accent-blue: #2563eb;--accent-green: #059669;--accent-red: #dc2626;--accent-purple: #7c3aed;--accent-orange: #eabe0c;--shadow-light: 0 1px 3px rgba(0, 0, 0, .15);--shadow-medium: 0 2px 6px rgba(0, 0, 0, .18);--shadow-strong: 0 4px 12px rgba(0, 0, 0, .22);--space: 8px;--radius: 8px;--font: 14px}.module-root .page-body h1,.module-root .page-body h2{color:var(--ink-black);text-shadow:0 1px 2px rgba(255,255,255,.8)}.module-root .page-body .panel h1:first-child{background:linear-gradient(145deg,var(--accent-orange) 0%,var(--ink-orange) 100%);color:var(--paper-white);text-shadow:0 1px 2px rgba(0,0,0,.3);border-bottom:2px solid var(--paper-gray);box-shadow:var(--shadow-medium),inset 0 1px #fff3}.module-root .page-body .panel h2:first-child{background:linear-gradient(145deg,var(--accent-blue) 0%,var(--ink-blue) 100%);color:var(--paper-white);text-shadow:0 1px 2px rgba(0,0,0,.3);border-bottom:2px solid var(--paper-gray);box-shadow:var(--shadow-medium),inset 0 1px #fff3}.module-root .page-body img{border-radius:var(--radius);border:3px solid var(--paper-dark-gray);box-shadow:var(--shadow-medium);transition:all .2s ease}.module-root .page-body table{font-size:var(--font);background:var(--paper-white);box-shadow:var(--shadow-medium)}.module-root .page-body th{background:gray;color:var(--paper-white);font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3)}.module-root .page-body td{background:var(--paper-white);color:var(--ink-black)}.module-root .page-body tr:last-child td{border-bottom:none}.module-root .page-body tr:nth-child(odd) td{background:var(--paper-beige)}.module-root .page-body .infobox{border-radius:var(--radius);background:var(--paper-beige);box-shadow:var(--shadow-medium);border:2px solid var(--paper-gray);transition:all .2s ease}.module-root .page-body .infobox:hover{box-shadow:var(--shadow-strong)}.module-root .page-body .infobox.definition{border-left:5px solid var(--accent-blue);border-right:5px solid var(--accent-blue)}.module-root .page-body .infobox.definition .header{color:var(--ink-blue)}.module-root .page-body .infobox.warning{border-left:5px solid var(--accent-orange);border-right:5px solid var(--accent-orange)}.module-root .page-body .infobox.warning .header{color:var(--ink-orange)}.module-root .page-body .infobox.example{border-left:5px solid var(--accent-green);border-right:5px solid var(--accent-green)}.module-root .page-body .infobox.example .header{color:var(--ink-green)}.module-root .page-body .infobox.hint{border-left:5px solid var(--accent-green);border-right:5px solid var(--accent-green)}.module-root .page-body .infobox.hint .header{color:var(--ink-green)}.module-root .page-body .infobox.hint .hint-placeholder{color:var(--ink-blue)}.module-root .page-body .infobox.hint .hint-content{color:#166534}.module-root .page-body .infobox.hint.hidden:hover{background-color:#dbeafe;border-color:#2563eb}.module-root .page-body .infobox.hint.revealed{cursor:default;border-style:solid;background-color:#f0fdf4;border-color:#22c55e;display:block}.module-root .page-body code:not(pre code){font-family:Monaco,Menlo,Ubuntu Mono,monospace;background:var(--paper-beige);color:var(--ink-purple);padding:2px 4px;border-radius:calc(var(--radius) / 2);border:1px solid var(--paper-gray);font-weight:600;font-size:calc(var(--font) - 1px);box-shadow:inset 0 1px 2px #0000001a}.module-root .page-body pre{background:var(--paper-beige);color:var(--ink-black);padding:var(--space);border-radius:var(--radius);border:2px solid var(--paper-gray);box-shadow:var(--shadow-medium);overflow-x:auto}.module-root .page-body a{color:var(--ink-blue);text-decoration:underline;font-weight:600;transition:all .2s ease}.module-root .page-body a:hover{color:var(--accent-blue);text-shadow:0 1px 2px rgba(37,99,235,.3)}.module-root .page-body blockquote{background:var(--paper-beige);border-left:4px solid var(--accent-purple);margin:calc(var(--space) * 2) 0;padding:var(--space) calc(var(--space) * 2);border-radius:0 var(--radius) var(--radius) 0;box-shadow:var(--shadow-light);font-style:italic;color:var(--ink-black)}.module-root .page-body ul,.module-root .page-body ol{padding-left:calc(var(--space) * 2)}.module-root .page-body li{margin-bottom:calc(var(--space) / 2);color:var(--ink-black)}.module-root .page-body li::marker{color:var(--accent-blue);font-weight:700}.navbar{display:flex;flex:1;width:100%;max-width:100%;box-sizing:border-box;align-items:center;justify-content:space-between;padding:12px 24px;background:linear-gradient(135deg,#2c3e50,#34495e);border-bottom:3px solid #1a252f;box-shadow:0 2px 8px #0003}.navbar-brand .brand-link{color:#667eea;font-weight:700;font-size:28px;text-decoration:none;display:inline-block;flex-shrink:0;transition:all .3s ease;letter-spacing:-.5px}.navbar-brand .brand-link .brand-link{color:#667eea;font-weight:700;font-size:28px;text-decoration:none;display:inline-block;transition:all .3s ease;letter-spacing:-.5px;text-shadow:0 2px 4px rgba(102,126,234,.2)}.navbar-brand .brand-link .brand-link{color:#ecf0f1;text-decoration:none;font-size:1.5rem;font-weight:700;transition:color .2s ease}.navbar-brand .brand-link .brand-link:hover{color:#764ba2;transform:translateY(-1px)}.navbar-brand .brand-link .brand-link:hover{color:#764ba2;text-shadow:0 2px 6px rgba(118,75,162,.3)}.navbar-links{display:flex;gap:24px;flex:1;box-sizing:border-box;flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:center}.nav-link{color:#bdc3c7;text-decoration:none;padding:8px 16px;border-radius:6px;transition:all .2s ease;font-weight:500}.nav-link:hover{color:#ecf0f1;background:#4a5c6b;transform:translateY(-1px)}.nav-link.active{color:#ecf0f1;background:#2980b9;border:1px solid #3498db}.nav-link.active:after{content:"";bottom:-3px;left:50%;transform:translate(-50%);width:4px;height:4px;background:#3498db;border-radius:50%}.navbar-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}@media (max-width: 768px){.navbar{flex-direction:column;gap:12px;padding:16px}.navbar-links{gap:16px;flex-wrap:wrap;justify-content:center}.nav-link{padding:6px 12px;font-size:.9rem}.brand-link{font-size:1.3rem}}@media (max-width: 480px){.navbar-links{gap:8px}.nav-link{padding:4px 8px;font-size:.85rem}.theme-selector{font-size:.85rem;padding:4px 8px}}.login-root .page-body .page-panel{display:flex;flex-direction:column;align-items:center}.login-root .page-body form{display:flex;flex-direction:column;gap:20px}.login-root .page-body h2{text-align:center;color:#1a202c;margin-bottom:30px;font-size:2rem;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.1)}.login-root .page-body .panel{max-width:400px;border-radius:20px;padding:40px;display:flex;flex-direction:column;align-items:center;gap:20px;background:#fffffffa;box-shadow:0 25px 50px #00000040,0 0 0 1px #ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid rgba(255,255,255,.3)}.login-root .page-body .form-group{display:flex;flex-direction:column;gap:8px;width:100%}.login-root .page-body input{padding:15px 20px;border:2px solid #cbd5e1;border-radius:12px;font-size:16px;transition:all .3s ease;background:#f8fafc;color:#1a202c;width:100%;box-sizing:border-box}.login-root .page-body input:focus{outline:none;border-color:#2563eb;background:#fff;box-shadow:0 0 0 4px #2563eb26,0 4px 12px #2563eb1a;transform:translateY(-2px)}.login-root .page-body input::placeholder{color:#64748b}.login-root .page-body .submit-button{padding:15px 30px;background:linear-gradient(135deg,#1e40af,#2563eb,#3b82f6);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;margin-top:10px;box-shadow:0 4px 15px #2563eb66;text-shadow:0 1px 2px rgba(0,0,0,.1)}.login-root .page-body .submit-button:hover{transform:translateY(-3px);box-shadow:0 10px 30px #2563eb80;background:linear-gradient(135deg,#1d4ed8,#2563eb,#3b82f6)}.login-root .page-body .submit-button:active{transform:translateY(-1px);box-shadow:0 5px 20px #2563eb66}.login-root .page-body .error-message{background:#fef2f2;color:#b91c1c;padding:12px 16px;border-radius:8px;border-left:4px solid #dc2626;font-size:14px;margin-top:10px;font-weight:500;box-shadow:0 2px 8px #dc26261a}.login-root .page-body .success-message{background:#f0fdf4;color:#166534;padding:12px 16px;border-radius:8px;border-left:4px solid #16a34a;font-size:14px;margin-top:10px;font-weight:500;box-shadow:0 2px 8px #16a34a1a}.login-root .page-body .auth-divider{margin:30px 0;text-align:center;position:relative;color:#64748b;font-weight:500}.login-root .page-body .auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#cbd5e1,transparent)}.login-root .page-body .auth-divider span{background:#fffffffa;padding:0 20px;font-weight:600}.login-root .page-body .logout-section{text-align:center;padding:40px}.login-root .page-body .user-info{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);padding:20px;border-radius:12px;margin-bottom:20px;color:#1a202c;border:1px solid #cbd5e1;box-shadow:0 2px 8px #0000000d}.login-root .page-body .logout-button{padding:12px 30px;background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 3px 10px #dc26264d}.login-root .page-body .logout-button:hover{background:linear-gradient(135deg,#b91c1c,#dc2626);transform:translateY(-2px);box-shadow:0 6px 20px #dc262666}.login-root .page-body .user-panel{width:100%;max-width:500px}.login-root .page-body .user-info-section,.login-root .page-body .user-actions-section{width:100%;margin-bottom:20px}.login-root .page-body .info-row{display:flex;margin-bottom:8px}.login-root .page-body .info-label{min-width:120px;font-weight:700}.login-root .page-body h3{margin-top:0;margin-bottom:15px}.login-root .page-body .logout-container{margin-top:25px;text-align:center}.login-root .page-body .input-button-row{display:flex;gap:8px}.login-root .page-body .input-button-row input{flex:1}@media (max-width: 480px){.login-page-root .panel{padding:30px 20px;margin:10px}.login-page-root h2{font-size:1.5rem}.login-page-root input,.login-page-root .submit-button{padding:12px 16px}}.about-root .page-body,.legal-root .page-body{display:flex;flex-direction:column;align-items:center}.about-root .page-body .page-panel,.legal-root .page-body .page-panel{width:fit-content;max-width:1000px}.about-root .page-body .about-panel,.legal-root .page-body .about-panel{margin-bottom:30px}.about-root .page-body .about-panel:last-child,.legal-root .page-body .about-panel:last-child{margin-bottom:0}.about-root .page-body .about-hero,.legal-root .page-body .about-hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;padding:60px 20px;border-radius:16px;box-shadow:0 8px 16px #00000026}.about-root .page-body .about-hero h1,.legal-root .page-body .about-hero h1{margin:0 0 15px;font-size:3em;font-weight:700}.about-root .page-body .about-hero p,.legal-root .page-body .about-hero p{font-size:1.2em;opacity:.9;margin:0 auto;max-width:600px}.about-root .page-body .features-grid-about,.legal-root .page-body .features-grid-about{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-top:25px}.about-root .page-body .feature-icon-about,.legal-root .page-body .feature-icon-about{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5em;margin-bottom:20px;background-color:#f0f2ff;color:#667eea}.about-root .page-body .feature-item h3,.legal-root .page-body .feature-item h3{margin:0 0 10px;color:#333;font-size:1.5em;font-weight:600}.about-root .page-body .feature-item p,.legal-root .page-body .feature-item p{color:#666;line-height:1.6}.about-root .page-body .how-it-works-container,.legal-root .page-body .how-it-works-container{margin-top:25px}.about-root .page-body .step-item,.legal-root .page-body .step-item{display:flex;align-items:flex-start;gap:20px;margin-bottom:25px}.about-root .page-body .step-item:last-child,.legal-root .page-body .step-item:last-child{margin-bottom:0}.about-root .page-body .step-number,.legal-root .page-body .step-number{width:45px;height:45px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2em;flex-shrink:0}.about-root .page-body .step-number.step-1,.legal-root .page-body .step-number.step-1{background:linear-gradient(135deg,#10b981,#059669)}.about-root .page-body .step-number.step-2,.legal-root .page-body .step-number.step-2{background:linear-gradient(135deg,#3b82f6,#2563eb)}.about-root .page-body .step-number.step-3,.legal-root .page-body .step-number.step-3{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.about-root .page-body .step-content h3,.legal-root .page-body .step-content h3{margin:0 0 8px;color:#333;font-size:1.4em;font-weight:600}.about-root .page-body .step-content p,.legal-root .page-body .step-content p{color:#666;line-height:1.6;margin:0}.about-root .page-body .tech-panel,.legal-root .page-body .tech-panel{background:#f8fafc;border:1px solid #e2e8f0}.about-root .page-body .tech-panel h2,.legal-root .page-body .tech-panel h2{margin-top:0;font-size:1.8em;font-weight:600}.about-root .page-body .tech-panel p,.legal-root .page-body .tech-panel p{color:#555;line-height:1.8;margin-bottom:20px}.about-root .page-body .tech-panel ul,.legal-root .page-body .tech-panel ul{color:#555;line-height:2;padding-left:20px}.about-root .page-body .cta-panel,.legal-root .page-body .cta-panel{text-align:center;padding:40px 30px;background-color:#f0f2ff}.about-root .page-body .cta-panel h2,.legal-root .page-body .cta-panel h2{margin-top:0;font-size:1.8em;font-weight:600;color:#333}.about-root .page-body .cta-panel p,.legal-root .page-body .cta-panel p{color:#555;margin-bottom:25px;font-size:1.1em}.about-root .page-body .cta-button,.legal-root .page-body .cta-button{padding:15px 40px;font-size:1.1em;font-weight:700}.loading-container{width:fit-content;height:fit-content;display:flex;flex-direction:column;align-items:center;justify-content:center}.loading-container.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;z-index:10;width:100%;height:100%}.spinner-page-root .page-body{position:relative}.loading-container.loading-overlay{background:#ffffff65;color:#1a1a1a;border-radius:8px;font-size:13px;font-weight:600;animation:fadeIn .3s ease-out}.loading-spinner{width:30px;height:30px;border:5px solid #f0ede8;border-top:5px solid #1e3a8a;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner.loading-spinner-crazy{animation:crazySpinner 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes crazySpinner{0%{transform:rotate(0) scale(1);border-radius:50%}25%{transform:rotate(90deg) scale(1.5);border-radius:30%;border-top-color:#ff6b6b;border-right-color:#4ecdc4}50%{transform:rotate(180deg) scale(.8);border-radius:10%;border-bottom-color:#45b7d1;border-left-color:#f9ca24}75%{transform:rotate(270deg) scale(1.2);border-radius:70%;border-top-color:#6c5ce7;border-right-color:#ff9ff3}to{transform:rotate(360deg) scale(1);border-radius:50%;border-bottom-color:#54a0ff;border-left-color:#5f27cd}}.learning-root .page-body{display:flex;flex-direction:column;align-items:center}.learning-root .page-body .page-panel{width:100%;gap:10px}.learning-root .page-body .page-panel .page-panel-mid{display:flex;flex-direction:column;align-items:center;padding-bottom:40vh}.learning-root .page-body .page-panel .page-panel-right{top:15px;position:sticky}.learning-root .page-body .progress-percentage{font-size:2.5rem;font-weight:700;border-radius:15px;border:solid black 2px;padding:10px 30px;background-color:#fff;color:#4caf50}.learning-root .page-body .learning-path{display:flex;flex-direction:column;align-items:center;gap:4rem;position:relative;padding:2rem 0}.learning-root .page-body .module-node{width:130px;height:auto;position:relative;display:flex;flex-direction:column;align-items:center;gap:10px;transition:transform .3s ease;z-index:2}.learning-root .page-body .module-link{text-decoration:none;color:inherit;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;width:130px;height:130px;border-radius:50%;background:#fff;box-shadow:0 0 0 1px #333c,1px 0 0 1px #333333b3,-1px 0 0 1px #333333b3,0 1px 0 1px #333c,0 -1px 0 1px #333333b3,2px 1px 0 1px #3339,-2px -1px 0 1px #3339,1px 2px 0 2px #33333380,-1px -2px 0 2px #33333380}.learning-root .page-body .module-title-path{text-align:center;font-size:14px;max-width:130px;word-wrap:break-word}.learning-root .page-body .module-link:hover{transform:scale(1.05);box-shadow:0 6px 25px #00000026,0 0 0 1px #333c,1px 0 0 1px #333333b3,-1px 0 0 1px #333333b3,0 1px 0 1px #333c,0 -1px 0 1px #333333b3,2px 1px 0 1px #3339,-2px -1px 0 1px #3339,1px 2px 0 2px #33333380,-1px -2px 0 2px #33333380}.learning-root .page-body .module-node--left{transform:translate(-180px)}.learning-root .page-body .module-node--right{transform:translate(190px)}.learning-root .page-body .status-icon{width:35px;height:35px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#e0e0e0;color:#666;font-weight:700;margin-bottom:8px;flex-shrink:0}.learning-root .page-body .status-icon.completed{background:#4caf50;color:#fff}.learning-root .page-body .module-title-path{font-size:.9rem;font-weight:500;color:#333;line-height:1.2}.home-root .page-body{display:flex;flex-direction:column;align-items:center}.home-root .page-body .page-panel{width:fit-content;max-width:1000px}.home-root .page-body .hero-panel{text-align:center;padding:100px 40px;margin-bottom:60px;border-radius:24px;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 20px 60px #667eea4d;position:relative;overflow:hidden}.home-root .page-body .hero-panel:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.home-root .page-body .hero-panel h1{font-size:3.8em;font-weight:800;margin-bottom:20px;letter-spacing:-1px;position:relative;z-index:1}.home-root .page-body .hero-panel p{font-size:1.3em;margin-bottom:40px;max-width:650px;margin-left:auto;margin-right:auto;opacity:.95;line-height:1.6;position:relative;z-index:1}.home-root .page-body .hero-buttons{display:flex;justify-content:center;gap:16px;position:relative;z-index:1}.home-root .page-body .hero-button-primary,.home-root .page-body .hero-button-secondary{padding:15px 32px;border:2px solid transparent;border-radius:10px;font-weight:700;font-size:1em;cursor:pointer;transition:all .3s ease}.home-root .page-body .hero-button-primary{background-color:#fff;color:#5e72e4}.home-root .page-body .hero-button-secondary{background-color:transparent;color:#fff;border:2px solid white}.home-root .page-body .hero-button-primary:hover,.home-root .page-body .hero-button-secondary:hover{transform:translateY(-3px);box-shadow:0 4px 15px #0003}.home-root .page-body .hero-button-primary:hover{background-color:#f0f2ff}.home-root .page-body .hero-button-secondary:hover{background-color:#ffffff1a}.home-root .page-body .features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}.home-root .page-body .feature-panel{background-color:#fff;padding:30px;border-radius:16px;text-align:left;box-shadow:0 4px 12px #00000014;transition:transform .3s ease,box-shadow .3s ease}.home-root .page-body .feature-panel:hover{transform:translateY(-5px);box-shadow:0 8px 20px #0000001f}.home-root .page-body .feature-icon{font-size:2.5em;margin-bottom:20px;background-color:#e8ecff;width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#5e72e4}.home-root .page-body .feature-title{font-size:1.5em;font-weight:600;margin-bottom:10px;color:#333}.home-root .page-body .feature-description{color:#666;line-height:1.6}.runner-root{padding:0;gap:8px;position:relative}.runner-root .toolbar{display:flex;flex-direction:row;align-items:center}.runner-root .toolbar .status{display:flex}.runner-root .toolbar input[type=range],.runner-root .spacer{flex-grow:1}.runner-root .two-side-panel{position:relative;display:flex;flex-direction:row}.runner-root .two-side-panel>.main-bar{flex:1 1 content;min-width:0;overflow:hidden}.runner-root .two-side-panel>.secondary-bar{flex:0 1 content;min-width:200px}.runner-root .inspect-panel{flex:0 1 content}.runner-root .editor-container{overflow:hidden}.runner-root .console-output{min-height:0;flex:1 1 content;font-family:monospace;white-space:pre-wrap;word-break:break-word}.runner-root .debug-bar{overflow:hidden;min-height:0;white-space:pre-wrap;word-break:break-word}.runner-root .test-bar{overflow:hidden;min-height:0;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start}.runner-root .test-toolbar{display:flex;flex-direction:row;justify-content:flex-start;align-items:center}.runner-root .test-bar button{flex:0 1 auto}.runner-root .test-summary>h2{margin:0}.runner-root .console-input{display:flex;justify-content:space-between;align-items:stretch}.runner-root .console-input input[type=text]{flex:1;box-sizing:border-box}.runner-root .current-line-glyph:before{content:"▶";position:relative}.runner-root .error-line-glyph:before{content:"✖";position:relative}.runner-root .error-line{font-family:monospace;white-space:pre-wrap;word-break:break-word}.runner-root .stack-frame{overflow:hidden}.runner-root .frame-header{display:flex;justify-content:space-between;align-items:center}.runner-root .function-name{min-width:60px}.runner-root .variable-entry{display:flex;align-items:flex-start}.runner-root .variable-name{min-width:60px}.runner-root .variable-value{white-space:pre-wrap;word-break:break-word;flex:1}@keyframes slideIn{0%{transform:translate(20px)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.module-root .page-body{display:flex;flex-direction:column;align-items:center;position:relative}.module-root .page-body .page-panel-mid{display:flex;flex-direction:column;align-items:center;padding-bottom:40vh}.module-root .page-body .page-panel-right{top:15px;position:sticky}.module-root .page-body .page-panel-right .panel{overflow:hidden}.module-root .page-body .page-panel-right .panel .return-button-container{margin:5px}.module-root .page-body .page-panel-right .panel .return-button-container button{width:100%}.module-root .page-body .runner-wrapper{width:100%;height:fit-content;position:relative}.module-root .page-body .checkmark-wrapper{background-color:#0fb152;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 8px #9efff2a2;opacity:0;transform:scale(0);animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) forwards}.module-root .page-body .checkmark-icon{color:#fff}.module-root .page-body .checkmark-icon path{stroke-dasharray:24;stroke-dashoffset:24;animation:drawStroke .4s ease-out forwards;animation-delay:.2s}.module-root .page-body .info-icon-container{position:relative;display:inline-flex;align-items:center;vertical-align:middle;cursor:help}.module-root .page-body .info-icon-icon{color:#575757}.module-root .page-body .info-icon-tooltip{visibility:hidden;position:absolute;top:100%;left:100%;padding:4px 6px;border-radius:4px;min-width:80px;max-width:280px;width:max-content;z-index:100;opacity:0;background-color:#636363;color:#fff;font-size:12px;font-weight:400;transition:opacity .3s}.module-root .page-body .info-icon-container:hover .info-icon-tooltip{visibility:visible;opacity:1}.module-root .page-body h1,.module-root .page-body h2{text-align:center}.module-root .page-body .panel>h1:first-child,.module-root .page-body .panel>h2:first-child,.module-root .page-body .panel>h3:first-child{text-align:center;margin-top:-15px;margin-left:-15px;margin-right:-15px;padding:5px;border-top-left-radius:15px;border-top-right-radius:15px}.module-root .page-body .panel>h1,.module-root .page-body .panel>h2,.module-root .page-body .panel>h3,.module-root .page-body .panel>h4,.module-root .page-body .panel>div{margin-top:15px}.module-root .page-body img{max-width:40%;border-width:3px}.module-root .page-body table{width:100%;border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden;border:1px solid gray}.module-root .page-body table th{padding:5px 15px;text-align:left;font-weight:700;border-bottom:1px solid gray}.module-root .page-body table td{padding:12px 15px;border-bottom:1px solid lightgray}.module-root .page-body .infobox{margin:15px 0;padding:15px;border-left:5px solid;border-right:5px solid;display:block}.module-root .page-body .infobox .header{font-weight:700;margin-bottom:10px}.module-root .page-body .infobox.hint.hidden{cursor:pointer;display:flex;flex-direction:column;align-items:center}.module-root .page-body .infobox.hint.hidden .header{width:fit-content}.module-root .page-body code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@keyframes popIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}@keyframes drawStroke{to{stroke-dashoffset:0}}.exercises-root .page-body .page-panel{max-width:1000px;margin:0 auto;padding:2rem}.exercises-root .page-body .exercises-header{text-align:center;margin-bottom:3rem}.exercises-root .page-body .exercises-header h1{font-size:2.5rem;margin-bottom:.5rem;color:#333}.exercises-root .page-body .exercises-header p{color:#666;font-size:1.1rem}.exercises-root .page-body .exercises-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.exercises-root .page-body .exercise-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;text-decoration:none;color:inherit;transition:all .2s ease;display:flex;flex-direction:column;min-height:150px;position:relative}.exercises-root .page-body .exercise-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001a;border-color:#d1d5db}.exercises-root .page-body .exercise-card-content{flex:1}.exercises-root .page-body .exercise-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:#1f2937}.exercises-root .page-body .exercise-description{color:#6b7280;font-size:.9rem;line-height:1.5}.exercises-root .page-body .exercise-tag{position:absolute;bottom:1rem;right:1rem;background:#fbbf24;color:#78350f;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.exercises-root .page-body .exercises-filter{margin-top:1.5rem;display:flex;align-items:center;justify-content:left;gap:.5rem}.exercises-root .page-body .exercises-filter label{font-size:1rem;color:#333}.exercises-root .page-body .tag-dropdown{padding:.5rem 1rem;font-size:1rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;transition:border-color .2s}.exercises-root .page-body .tag-dropdown:hover{border-color:#d1d5db}.exercises-root .page-body .tag-dropdown:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}html,body,#root{height:100%;width:100%;overflow:hidden;margin:0;padding:0;font-family:Nunito,sans-serif;background-color:#537ba3}.page-root{display:flex;flex-direction:column;align-items:center;width:100%;height:100%;overflow:hidden}.page-body{box-sizing:border-box;width:100%;height:100%;overflow-y:auto;background:linear-gradient(348deg,#2a489b,#53b2ed)}.page-panel{width:100%;overflow-x:visible;box-sizing:border-box;padding:15px}.page-panel.sidebars{width:100%;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:flex-start;justify-content:center;gap:10px}.page-panel.sidebars .page-panel-left{flex:0 1 auto;height:fit-content;width:fit-content;min-width:100px;min-height:100px}.page-panel.sidebars .page-panel-mid{flex:1 1 auto;width:fit-content;height:fit-content;max-width:900px;min-width:250px}.page-panel.sidebars .page-panel-right{flex:0 1 auto;height:fit-content;width:fit-content;min-width:100px;min-height:100px}.panel{display:block;box-sizing:border-box;width:100%;height:fit-content;overflow:visible;padding:15px;margin:12px;background-color:#fff;color:#34495e;border-radius:15px;box-shadow:0 4px 12px #0000001a}.invisible-container{display:contents}button{border-radius:8px;border:1px solid gray;cursor:pointer;padding:6px 15px;font-size:16px;box-shadow:0 2px 5px #00000026;color:#34495e;display:inline-flex;align-items:center;justify-content:center}button:disabled{opacity:.5;cursor:not-allowed}button.exit{padding:7px}button.green{background-color:#1ac05f;color:#fff}button.green:hover{background-color:#27ae60}button.blue{background-color:#2563eb;color:#fff}button.blue:hover{background-color:#1d4ed8}button.red{background-color:#e63946;color:#fff}button.red:hover{background-color:#d62839}button.yellow{background-color:#f1c40f;color:#fff}button.yellow:hover{background-color:#f39c12}
