:root{--editor-font-size: 14px}*{margin:0;padding:0;box-sizing:border-box}@font-face{font-family:DejaVu Sans Mono Bold;src:url(/assets/DejaVuSansMono-Bold-BIlWjo3t.ttf) format("truetype");font-weight:700;font-style:normal}html,body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#20b2aa);min-height:100vh}body{padding:16px;overflow-y:auto;background-attachment:fixed;position:relative}#loading{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:1000}.spinner{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 2s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#loading p{color:#fff;font-size:1.2em;margin:0}.container{max-width:1600px;margin:0 auto;background:#fff;border-radius:15px;box-shadow:0 20px 60px #0000004d;overflow:visible;display:flex;flex-direction:column;min-height:calc(100vh - 40px)}.container>.panel:first-child{border-top-left-radius:15px;border-top-right-radius:15px}.header{background:linear-gradient(135deg,#667eea,#20b2aa);color:#fff;padding:12px;text-align:center;border-top-left-radius:15px;border-top-right-radius:15px;overflow:hidden}.header h1{font-size:2.5em;margin-bottom:10px}.header p{font-size:1.1em;opacity:.9}.main-content{display:grid;grid-template-columns:3fr 1fr;gap:12px;padding:16px 24px;flex:1;align-items:stretch}.panel{background:#f8f9fa;border-radius:10px;padding:12px;border:2px solid #e9ecef;display:flex;flex-direction:column;min-height:0;height:100%}.panel:first-child{border-top-left-radius:10px;border-top-right-radius:10px}.panel:last-child{border-bottom-left-radius:10px;border-bottom-right-radius:10px}.editor-panel{display:flex;flex-direction:column;height:100%}.editor-panel .editor-container{flex:1 1 auto;min-height:0;height:auto;padding-top:0}.editor-panel .code-editor{height:100%}.editor-panel .line-numbers{height:auto;overflow-y:auto}.panel h2{color:#667eea;margin-bottom:10px;font-size:1.5em}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.panel-header h2{margin-bottom:0;flex:1;min-width:0}.panel-header .controls{margin-bottom:0;margin-left:auto}.panel-header .controls select{min-width:150px;max-width:200px;width:auto}.controls{display:flex;gap:10px;margin-bottom:12px;flex-wrap:wrap}label{font-weight:600;color:#495057;display:flex;align-items:center;gap:10px}select{padding:10px 5px;border:2px solid #dee2e6;border-radius:8px;font-size:1em;background:#fff;cursor:pointer;transition:all .3s}select:hover{border-color:#667eea}select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.font-size-controls{display:flex;align-items:center;gap:5px}.font-size-controls button{padding:5px;border:2px solid #dee2e6;border-radius:5px;background:#fff;cursor:pointer;font-size:1em;transition:all .3s}.font-size-controls button:hover{border-color:#667eea;background:#f8f9fa}.font-size-controls button:active{background:#e9ecef}#fontSizeDisplay{font-size:.9em;color:#6c757d;min-width:35px;text-align:center}.editor-container{display:flex;position:relative;align-items:stretch;gap:0;width:100%}.editor-area{position:relative;flex:1 1 auto;min-width:0}.highlight-layer{position:absolute;inset:0;pointer-events:none;padding:12px;overflow:auto;white-space:pre-wrap;word-wrap:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,DejaVu Sans Mono,monospace;font-size:var(--editor-font-size);line-height:1.5;color:#222;z-index:10}.code-editor{position:relative;z-index:5;caret-color:#111}.highlight-layer pre{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}.line-numbers{background:#f8f9fa;border:2px solid #dee2e6;border-right:none;padding:12px 8px;font-family:DejaVu Sans Mono,monospace;font-size:var(--editor-font-size);color:#6c757d;text-align:right;font-variant-numeric:tabular-nums;min-width:50px;line-height:1.5;justify-content:flex-start;white-space:pre;overflow:hidden;align-self:stretch;display:flex;flex-direction:column}.code-editor{flex:1 1 auto;width:100%;height:auto;padding:12px;border:2px solid #dee2e6;border-left:none;border-radius:0 8px 8px 0;font-family:DejaVu Sans Mono,monospace;font-size:var(--editor-font-size);box-sizing:border-box;resize:vertical;background:#fff;transition:all .3s;line-height:1.5;overflow-y:auto;white-space:pre-wrap}.code-editor{color:transparent;background:transparent;caret-color:#111;position:relative;z-index:2}.code-editor.overlay-active,.code-editor.overlay-active:focus{color:transparent!important;-webkit-text-fill-color:transparent!important}.code-editor:not(.overlay-active):focus{color:#111}.code-editor::selection{background:#667eea2e}.token-keyword{color:#7b5cff;font-weight:700;font-family:DejaVu Sans Mono Bold,DejaVu Sans Mono,monospace}.token-number{color:#d73a49}.token-string{color:#22863a}.token-operator{color:#a97900}.token-comment{color:#6a737d;font-style:italic}textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.button-group{display:flex;gap:8px;margin-top:10px;position:relative;z-index:2000}button{flex:1;padding:12px 25px;border:none;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s;text-transform:uppercase;letter-spacing:.5px}.btn-run{background:linear-gradient(135deg,#667eea,#20b2aa);color:#fff}.btn-run:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-validate{background:linear-gradient(135deg,#20b2aa,#667eea);color:#fff}.btn-validate:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-clear{background:#6c757d;color:#fff}.btn-clear:hover{background:#5a6268;transform:translateY(-2px)}.btn-save{background:none;color:#333;padding:12px 5px;font-size:1.2em;border-radius:8px;flex:none}.btn-save:hover{background:#0000001a;transform:none;box-shadow:none}.btn-load{background:none;color:#333;padding:12px 5px;font-size:1.2em;border-radius:8px;flex:none}.btn-load:hover{background:#0000001a;transform:none;box-shadow:none}.output-area{background:#1e1e1e;color:#d4d4d4;padding:12px;border-radius:8px;font-family:DejaVu Sans Mono,monospace;font-size:calc(var(--editor-font-size) - 2px);line-height:1.5;flex:1;min-height:0;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word}.validation-result{padding:15px;border-radius:8px;margin-top:15px;font-weight:600}.validation-success{background:#d4edda;color:#155724;border:2px solid #c3e6cb}.validation-error{background:#f8d7da;color:#721c24;border:2px solid #f5c6cb}.validation-warning{background:#fff3cd;color:#856404;border:2px solid #ffeaa7}.info-section{grid-column:1 / -1;background:#e7f3ff;border-left:4px solid #667eea;padding:12px;border-radius:8px}.info-section h3{color:#667eea;margin-bottom:10px}.info-section ul{margin-left:20px;line-height:1.8}.examples{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px;margin-top:15px}.example-card{background:#fff;padding:15px;border-radius:8px;cursor:pointer;transition:all .3s;border:2px solid #dee2e6}.example-card:hover{transform:translateY(-3px);box-shadow:0 5px 15px #0000001a;border-color:#667eea}.error-line{background-color:#fcc;color:#d9534f;font-weight:700;padding:0 2px;border-radius:2px}.example-card h4{color:#667eea;margin-bottom:5px}@media(max-width:968px){.main-content{grid-template-columns:1fr}.panel-header{flex-direction:column;align-items:flex-start;gap:8px}}body::-webkit-scrollbar,.output-area::-webkit-scrollbar{display:none}#bg-splash{content:"";position:fixed;left:0;right:0;top:-200vh;height:500vh;background:linear-gradient(135deg,#667eea,#20b2aa);z-index:-10000;pointer-events:none}footer{text-align:center;padding:10px 20px;color:#ffffffe6;font-size:12px;background:#000000b3;z-index:9999;cursor:default;position:fixed;left:0;right:0;bottom:0;transform:translateY(100%);visibility:hidden;transition:transform .3s ease-in-out,opacity .3s ease-in-out;opacity:0;pointer-events:none}footer.footer--visible{transform:translateY(0);opacity:1;pointer-events:auto;visibility:visible}.code-editor{scrollbar-width:auto;-ms-overflow-style:auto}.code-editor::-webkit-scrollbar{width:12px}.code-editor::-webkit-scrollbar-track{background:#0000000d;border-radius:8px}.code-editor::-webkit-scrollbar-thumb{background:#0000002e;border-radius:8px;border:2px solid rgba(255,255,255,0)}.file-tabs{display:flex;border-bottom:1px solid #ddd;margin-bottom:10px}.file-tab{padding:8px 16px;background:#f5f5f5;border:1px solid #ddd;border-bottom:none;cursor:pointer;margin-right:2px;border-radius:4px 4px 0 0}.file-tab.active{background:#fff;border-bottom:1px solid white}.file-tab.close-btn{margin-left:8px;color:red;font-weight:700}.file-contents{background:#fff;border:1px solid #ddd;padding:10px;min-height:200px;white-space:pre-wrap;font-family:DejaVu Sans Mono,monospace;font-size:var(--editor-font-size)}.editor-tabs{display:flex}.editor-tab{padding:8px 16px;background:#f5f5f5;border-bottom:none;cursor:pointer;margin-right:2px;border-radius:4px 4px 0 0}.editor-tab.add-tab{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background:#f5f5f5;border:1px solid #ddd;border-bottom:none;cursor:pointer;margin-right:2px;border-radius:4px 4px 0 0;font-weight:700}.editor-tab.add-tab:hover{transform:translateY(-1px)}.add-menu{position:absolute;background:#fff;border:1px solid #e9ecef;box-shadow:0 6px 18px #00000014;border-radius:8px;padding:4px;z-index:8000;display:none;display:flex;gap:0;min-width:280px;overflow:hidden}.add-menu .btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;background:none;border:0;cursor:pointer;width:50%;font-weight:600}.add-menu .btn+.btn{border-left:1px solid #eaeaea}.add-menu .btn:hover{background:#f8f9fa}#modalOverlay{display:none;align-items:center;justify-content:center}#modal{border:2px solid #e7e7e7}#modal input{border:1px solid #ddd;border-radius:4px}#modal button{padding:8px 12px;border-radius:4px}.editor-tab.active{background:#fff;border-bottom:1px solid white}.editor-tab.close-btn{margin-left:8px;color:red;font-weight:700}.editor-tabs.hide-file-tabs .editor-tab,body.basic-mode .editor-tabs .editor-tab{display:none!important}.editor-tabs.hide-file-tabs,body.basic-mode .editor-tabs{margin-bottom:0!important}.tabs-header{display:flex;gap:2px}.panel-tab{padding:8px 16px;cursor:pointer;border-bottom:3px solid transparent;font-weight:600;color:#666;transition:all .2s;background:#f1f3f5;border-radius:6px 6px 0 0;margin-right:4px}.panel-tab:hover{color:#333;background:#e9ecef}.panel-tab.active{color:#667eea;border-bottom:3px solid #667eea;background:#fff}.variables-area{padding:0;overflow-y:auto;flex:1;min-height:0;background:#fff;border-radius:0 0 8px 8px}.var-table{width:100%;border-collapse:collapse;font-size:14px}.var-table th{text-align:left;padding:8px 12px;background:#f8f9fa;border-bottom:1px solid #dee2e6;color:#495057;font-weight:600;position:sticky;top:0;z-index:10}.var-table td{padding:8px 12px;border-bottom:1px solid #eee}.var-name{font-family:DejaVu Sans Mono,monospace;color:#d63384;font-weight:600}.var-type{color:#6c757d;font-size:.9em}.var-val{font-family:DejaVu Sans Mono,monospace;color:#212529}.debug-line-highlight{position:absolute;left:0;right:0;background-color:#ffff004d;pointer-events:none;z-index:8;border-left:4px solid #ffcc00}.btn-debug{background:linear-gradient(135deg,#ff9f43,#ff6b6b);color:#fff}.btn-debug:hover{transform:translateY(-2px);box-shadow:0 5px 15px #ff9f4366}.btn-step{background:linear-gradient(135deg,#54a0ff,#2e86de);color:#fff}.btn-step:hover{transform:translateY(-2px);box-shadow:0 5px 15px #2e86de66}.btn-stop{background:linear-gradient(135deg,#ff6b6b,#ee5253);color:#fff}.btn-stop:hover{transform:translateY(-2px);box-shadow:0 5px 15px #ee525366}.exam-toggle{background:#f8f9fa;padding:8px 12px;border-radius:20px;border:2px solid #dee2e6;cursor:pointer;transition:all .3s}.exam-toggle.active{background:#fff0f0;border-color:#ff6b6b;color:#c0392b;font-weight:700}.exam-mode .token-keyword,.exam-mode .token-string,.exam-mode .token-number,.exam-mode .token-comment,.exam-mode .token-operator{color:inherit!important;font-weight:inherit!important;font-style:inherit!important}.exam-mode .code-editor{color:var(--editor-fg, #000);font-weight:400;font-style:normal}.exam-mode .line-numbers{background:#eee;color:#888}#creditsOverlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;z-index:20000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}#creditsModal{background:var(--editor-bg);color:var(--text-color);width:500px;max-width:90%;max-height:80vh;border-radius:12px;box-shadow:0 20px 50px #00000080;display:flex;flex-direction:column;position:relative;border:1px solid var(--border-color);animation:popIn .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}#creditsClose{position:absolute;top:10px;right:15px;background:none;border:none;color:var(--text-secondary);font-size:28px;cursor:pointer;line-height:1;padding:0;transition:color .2s}#creditsClose:hover{color:var(--accent-red)}#creditsModal h2{margin:0;padding:20px 24px;border-bottom:1px solid var(--border-color);font-size:1.5em;font-weight:600}#creditsList{padding:20px 24px;overflow-y:auto;flex:1;font-size:.95em;line-height:1.6}#creditsList div{margin-bottom:8px;border-bottom:1px dashed var(--border-color);padding-bottom:4px}#creditsList div:last-child{border-bottom:none}
