@import "https://fonts.googleapis.com/css2?family=Tourney:ital,wght@0,100..900;1,100..900&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,700;1,9..40,300&family=DM+Mono:wght@400;500&display=swap";:root{--line-height:20px;--teal-deep:#0d9488;--teal-mid:#14b8a6;--teal-light:#7de2d1;--teal-pale:#b2f7ef;--dark:#0a1a18;--dark-2:#0f2420;--dark-3:#122b26;--glass:#ffffff0a;--glass-hover:#ffffff12;--glass-border:#7de2d126;--glass-border-bright:#7de2d159;--white:#fff;--muted:#ffffff73}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--dark);color:var(--white);flex-direction:column;min-height:100vh;font-family:DM Sans,sans-serif;display:flex;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(70% 50% at 15% 30%,#0d948824 0%,#0000 60%),radial-gradient(50% 70% at 85% 70%,#14b8a61a 0%,#0000 60%),radial-gradient(40% 40% at 50% 5%,#7de2d10f 0%,#0000 60%);animation:14s ease-in-out infinite alternate meshShift;position:fixed;inset:0}body:after{content:"";pointer-events:none;z-index:0;background-image:linear-gradient(#7de2d108 1px,#0000 1px),linear-gradient(90deg,#7de2d108 1px,#0000 1px);background-size:48px 48px;position:fixed;inset:0}@keyframes meshShift{0%{opacity:.7;transform:scale(1)}to{opacity:1;transform:scale(1.04)}}.app{z-index:1;flex-direction:column;width:100%;max-width:1400px;min-height:100vh;margin:0 auto;padding:0 24px 24px;display:flex;position:relative}header{padding:12px 0}#ad-div{opacity:.85;border-radius:8px;display:flex;overflow:hidden}.nav-bar{border-bottom:1px solid var(--glass-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;padding:16px 0 12px;display:flex}body h1{letter-spacing:-.03em;color:var(--teal-mid);white-space:nowrap;font-family:Tourney,sans-serif;font-size:clamp(1.8rem,4vw,3rem);font-weight:900;line-height:1}main{flex-direction:column;flex:1;gap:0;display:flex}#ide-container{flex-direction:column;display:flex}#IDE{flex-direction:column;gap:12px;display:flex}#controls{background:var(--glass);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;flex-wrap:wrap;align-items:center;gap:6px;padding:10px 14px;display:flex}#controls button,#controls a{border:1px solid var(--glass-border);color:var(--teal-light);cursor:pointer;white-space:nowrap;letter-spacing:.01em;background:0 0;border-radius:8px;align-items:center;gap:5px;padding:7px 14px;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s,color .15s,transform .1s;display:inline-flex}#controls button:hover,#controls a:hover{border-color:var(--teal-deep);color:var(--white);background:#0d948826;transform:translateY(-1px)}#controls button:active,#controls a:active{transform:translateY(0)}#controls #run{background:var(--teal-deep);border-color:var(--teal-deep);color:var(--white);padding:8px 20px;font-size:.88rem;font-weight:700;box-shadow:0 0 20px #0d948859}#controls #run:hover{background:var(--teal-mid);border-color:var(--teal-mid);transform:translateY(-1px);box-shadow:0 0 30px #0d94888c}#controls #run:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}#controls button.active{border-color:var(--teal-mid);color:var(--teal-pale);background:#0d948833}.ctrl-divider{background:var(--glass-border);flex-shrink:0;width:1px;height:22px;margin:0 2px}#workspace{gap:12px;display:flex}#workspace.vertical{flex-direction:column}#workspace.vertical #editor{height:360px;min-height:360px;max-height:360px;overflow:hidden}#workspace.vertical #output{height:220px;min-height:220px;max-height:220px;overflow-y:auto}#workspace.horizontal{flex-direction:row;height:560px;min-height:560px;max-height:560px}#workspace.horizontal #editor,#workspace.horizontal #output{width:50%;height:560px;min-height:560px;max-height:560px;overflow-y:auto}#editor{border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a1a18b3;border-radius:12px;flex-shrink:0;transition:border-color .2s;position:relative;overflow:hidden;box-shadow:inset 0 1px #7de2d10f,0 8px 32px #0000004d}#editor:before{content:"Python";color:#7de2d14d;letter-spacing:.08em;text-transform:uppercase;pointer-events:none;z-index:10;font-family:DM Mono,monospace;font-size:.68rem;position:absolute;top:10px;right:14px}#editor:focus-within{border-color:var(--glass-border-bright);box-shadow:inset 0 1px #7de2d114,0 8px 32px #0000004d,0 0 0 1px #0d948833}#output{border:1px solid var(--glass-border);color:#00ff41;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);white-space:pre-wrap;background:#0a1a18b3;border-radius:12px;flex-shrink:0;padding:14px 16px;font-family:DM Mono,monospace;font-size:.82rem;line-height:1.7;position:relative;overflow:auto;box-shadow:inset 0 1px #7de2d10a,0 8px 32px #0000004d}#output:before{content:"Output";letter-spacing:.12em;text-transform:uppercase;color:#7de2d14d;border-bottom:1px solid var(--glass-border);margin-bottom:10px;padding-bottom:8px;font-family:DM Sans,sans-serif;font-size:.68rem;font-weight:700;display:block}.cm-editor{height:100%;background:0 0!important}.cm-scroller{overflow:auto;font-family:DM Mono,monospace!important}.cm-content{line-height:var(--line-height);color:#ffffffd9;padding:12px 0}.cm-gutters{border-right:1px solid var(--glass-border)!important;color:#7de2d140!important;background:#0a1a1880!important}.cm-lineNumbers .cm-gutterElement{padding:0 10px;font-family:DM Mono,monospace;font-size:.75rem}.cm-activeLine{background:#7de2d10a!important}.cm-activeLineGutter{color:#7de2d180!important;background:#7de2d10f!important}.cm-selectionBackground{background:#0d948840!important}.cm-editor .cm-cursor{border-left-color:#00ff41!important}.cm-editor .cm-content{caret-color:#00ff41!important}.py-inline-input{color:#00ff41;caret-color:#00ff41;white-space:pre;background:0 0;border:none;outline:none;min-width:2px;font-family:DM Mono,monospace;font-size:.82rem;line-height:1.7;display:inline}.cm-editor .cm-error{color:inherit!important;text-decoration:none!important}.cm-lintRange-error{text-underline-offset:3px;background-image:none!important;-webkit-text-decoration:underline wavy #ef4444d9!important;text-decoration:underline wavy #ef4444d9!important;text-decoration-thickness:2px!important}.exam-banner{background:#f59e0b12;border:1px solid #f59e0b40;border-left:3px solid #f59e0b;border-radius:10px;align-items:flex-start;gap:14px;margin-bottom:12px;padding:12px 16px;display:flex}.exam-banner-icon{flex-shrink:0;margin-top:2px;font-size:1.4rem;line-height:1}.exam-banner-text{flex:1;min-width:0}.exam-banner-label{letter-spacing:.14em;text-transform:uppercase;color:#f59e0b;margin-bottom:3px;font-size:.65rem;font-weight:700}.exam-banner-title{color:var(--white);margin:0 0 3px;font-size:1.05rem;font-weight:700;line-height:1.3}.exam-banner-desc{color:var(--muted);margin:0;font-size:.8rem;line-height:1.5}.exam-badge{color:#f59e0b;letter-spacing:.1em;background:#f59e0b26;border:1px solid #f59e0b59;border-radius:6px;flex-shrink:0;align-self:center;padding:4px 10px;font-family:DM Mono,monospace;font-size:.65rem;font-weight:700}.lesson-banner{border:1px solid var(--glass-border);border-left:3px solid var(--teal-mid);background:#0d948812;border-radius:10px;align-items:flex-start;gap:14px;margin-bottom:12px;padding:12px 16px;display:flex}.lesson-banner-icon{flex-shrink:0;margin-top:2px;font-size:1.4rem;line-height:1}.lesson-banner-text{flex:1;min-width:0}.lesson-banner-label{letter-spacing:.14em;text-transform:uppercase;color:var(--teal-mid);margin-bottom:3px;font-size:.65rem;font-weight:700}.lesson-banner-title{color:var(--white);margin:0 0 3px;font-size:1.05rem;font-weight:700;line-height:1.3}.lesson-banner-desc{color:var(--muted);margin:0;font-size:.8rem;line-height:1.5}footer{border-top:1px solid var(--glass-border);color:var(--muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:12px;padding:16px 0 8px;font-size:.75rem;display:flex}footer a{color:var(--teal-mid);font-weight:500;text-decoration:none;transition:color .15s}footer a:hover{color:var(--teal-light)}.txt-popup{border:1px solid var(--glass-border-bright);z-index:9999;background:#0d1f1d;border-radius:10px;flex-direction:column;width:420px;font-family:DM Sans,sans-serif;display:flex;position:fixed;overflow:hidden;box-shadow:0 24px 60px #0009,0 0 0 1px #7de2d10d}.txt-popup.hidden{display:none}@keyframes popupFlash{0%{box-shadow:0 0 0 3px var(--teal-mid)}to{box-shadow:0 24px 60px #0009}}.txt-popup.popup-flash{animation:.4s ease-out forwards popupFlash}#txt-popup-header{cursor:grab;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--glass-border);color:var(--teal-light);letter-spacing:.02em;background:#0d948814;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.8rem;font-weight:600;display:flex}#txt-popup-header:active{cursor:grabbing}.txt-popup-header-btns{gap:4px;display:flex}.txt-popup-header-btns button{border:1px solid var(--glass-border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;width:22px;height:22px;padding:0;font-size:.78rem;line-height:1;transition:background .15s,color .15s,border-color .15s}.txt-popup-header-btns button:hover{background:var(--teal-deep);color:var(--white);border-color:var(--teal-deep)}#txt-popup-body{flex-direction:column;gap:10px;padding:14px;display:flex}#txt-filename,#txt-content{border:1px solid var(--glass-border);color:#ffffffd9;background:#0a1a18cc;border-radius:6px;outline:none;width:100%;font-family:DM Mono,monospace;transition:border-color .15s}#txt-filename:focus,#txt-content:focus{border-color:var(--teal-deep)}#txt-filename{padding:7px 10px;font-size:.82rem}#txt-content{resize:vertical;height:240px;padding:10px;font-size:.8rem;line-height:1.6}.txt-popup-actions{justify-content:flex-end;gap:8px;display:flex}.txt-popup-actions button{background:var(--glass);border:1px solid var(--glass-border);color:var(--teal-light);cursor:pointer;border-radius:6px;padding:7px 16px;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;transition:background .15s,color .15s,border-color .15s}.txt-popup-actions button:hover{background:var(--teal-deep);border-color:var(--teal-deep);color:var(--white)}.turtle-popup{border:1px solid var(--glass-border-bright);z-index:9998;background:#0d1f1d;border-radius:10px;flex-direction:column;width:524px;font-family:DM Sans,sans-serif;display:flex;position:fixed;top:60px;right:40px;overflow:hidden;box-shadow:0 24px 60px #0009,0 0 0 1px #7de2d10d}.turtle-popup.hidden{display:none}#turtle-popup-header{cursor:grab;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--glass-border);color:var(--teal-light);background:#0d948814;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.8rem;font-weight:600;display:flex}#turtle-popup-header:active{cursor:grabbing}.turtle-popup-header-btns{gap:4px;display:flex}.turtle-popup-header-btns button{border:1px solid var(--glass-border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;width:22px;height:22px;padding:0;font-size:.78rem;line-height:1;transition:background .15s,color .15s}.turtle-popup-header-btns button:hover{color:var(--white);background:#22c55e;border-color:#22c55e}#turtle-popup-body{flex-direction:column;gap:10px;padding:12px;display:flex}#turtle-canvas-wrap{border:1px solid var(--glass-border);border-radius:6px;width:500px;height:400px;position:relative;overflow:hidden}#turtle-canvas,#turtle-overlay{width:500px;height:400px;image-rendering:crisp-edges;display:block;position:absolute;top:0;left:0}#turtle-canvas{z-index:1;background:#fff}#turtle-overlay{z-index:2;pointer-events:none;background:0 0}.turtle-popup-actions{justify-content:flex-end;gap:8px;display:flex}.turtle-popup-actions button{background:var(--glass);border:1px solid var(--glass-border);color:var(--teal-light);cursor:pointer;border-radius:6px;padding:7px 16px;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;transition:background .15s,border-color .15s,color .15s}.turtle-popup-actions button:hover{color:var(--white);background:#22c55e;border-color:#22c55e}.info-popup{border:1px solid var(--glass-border-bright);z-index:9997;background:#0d1f1d;border-radius:10px;flex-direction:column;width:480px;max-height:80vh;font-family:DM Sans,sans-serif;display:flex;position:fixed;top:80px;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 24px 60px #0009}.info-popup.hidden{display:none}.info-popup-header{cursor:grab;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--glass-border);color:var(--teal-light);background:#0d948814;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.8rem;font-weight:600;display:flex}.info-popup-header:active{cursor:grabbing}.info-popup-header-btns{gap:4px;display:flex}.info-popup-header-btns button{border:1px solid var(--glass-border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;width:22px;height:22px;padding:0;font-size:.78rem;line-height:1;transition:background .15s,color .15s}.info-popup-header-btns button:hover{background:var(--teal-deep);color:var(--white);border-color:var(--teal-deep)}.info-popup-body{color:#fffc;flex-direction:column;gap:16px;padding:16px;font-size:.87rem;line-height:1.6;display:flex;overflow-y:auto}.info-section{border-bottom:1px solid var(--glass-border);flex-direction:column;gap:7px;padding-bottom:14px;display:flex}.info-section:last-child{border-bottom:none;padding-bottom:0}.info-section h3{color:var(--teal-light);font-size:.9rem;font-weight:700}.info-section p{color:var(--muted)}.info-section a{color:var(--teal-mid)}.info-list{color:var(--muted);flex-direction:column;gap:5px;margin:0;padding-left:18px;display:flex}.info-list li strong{color:#fffc}.info-table{border-collapse:collapse;width:100%;font-size:.82rem}.info-table td{vertical-align:top;color:var(--muted);padding:5px 8px}.info-table td:first-child{white-space:nowrap;color:#fffc;width:130px}.info-table tr:nth-child(2n) td{background:#7de2d108}.info-code{border:1px solid var(--glass-border);color:#a3e635;white-space:pre;background:#0a1a18cc;border-radius:6px;padding:10px 12px;font-family:DM Mono,monospace;font-size:.78rem;overflow-x:auto}kbd{border:1px solid var(--glass-border);color:var(--teal-light);background:#0d948826;border-radius:4px;padding:1px 6px;font-family:DM Mono,monospace;font-size:.78rem}.info-footer-note{text-align:center;opacity:.5;font-size:.75rem}.app{animation:.5s forwards appFadeIn}@keyframes appFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#7de2d133;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#7de2d166}
