*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;font-family:Arial,sans-serif;background:#f4f6fb}.app{display:grid;grid-template-columns:minmax(220px,22vw) 1fr minmax(220px,24vw);width:100vw;height:100vh;overflow:hidden}.left-panel{background:#f3fff4;padding:16px;overflow-y:auto;overflow-x:visible;border-right:4px solid #ccc;min-width:0}.right-panel{background:#fff8e8;padding:16px;overflow-y:auto;overflow-x:visible;border-left:4px solid #ccc;min-width:0}.canvas-panel{display:flex;justify-content:center;align-items:center;background:#fff4dd;overflow:auto;padding:10px;min-width:0}.canvas-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%}.canvas-title{font-size:clamp(18px,2vw,30px);margin-bottom:14px;color:#333;text-align:center;background:white;padding:12px 20px;border-radius:16px;border:3px solid #ddd;box-shadow:0 4px 10px rgba(0,0,0,0.1);position:relative;cursor:help;max-width:95%}#turtleCanvas{background:white;border:5px solid #ddd;border-radius:18px;box-shadow:0 0 20px rgba(0,0,0,0.15);width:min(100%,1000px);height:auto;aspect-ratio:1000 / 700;display:block}.logo-area{width:100%;display:flex;justify-content:center;align-items:center;margin-bottom:22px}.logo-image{width:110px;max-width:75%;height:auto}.section{margin-bottom:24px;padding:16px;border-radius:18px;border:4px solid #ddd;box-shadow:0 4px 10px rgba(0,0,0,0.08);position:relative;overflow:visible}.section:nth-of-type(1){background:#dff6ff;border-color:#66c7ff}.section:nth-of-type(2){background:#fff0d9;border-color:#ffb84d}.section:nth-of-type(3){background:#ffe4f1;border-color:#ff7eb6}.section:nth-of-type(4){background:#e7ffe7;border-color:#6c6}.section:nth-of-type(5){background:#f4e5ff;border-color:#b266ff}.section:nth-of-type(6){background:#dffbff;border-color:#00bcd4}.section:nth-of-type(7){background:#ffe9d9;border-color:#ff884d}.section:nth-of-type(8){background:#ececff;border-color:#88f}.section h2,.right-panel h2{margin-bottom:14px;color:#333;font-size:clamp(16px,1.6vw,22px);text-align:center;background:white;padding:10px;border-radius:12px;border:2px solid rgba(0,0,0,0.08);position:relative;cursor:help;overflow:visible}button{width:100%;padding:11px;margin-bottom:10px;border:0;border-radius:12px;background:#09f;color:white;font-weight:bold;font-size:14px;cursor:pointer;transition:.3s;box-shadow:0 3px 6px rgba(0,0,0,0.15)}button:hover{transform:scale(1.02);background:#07c}label{display:block;margin-bottom:6px;margin-top:10px;font-weight:bold;color:#333;font-size:13px}input,select,textarea{width:100%;margin-bottom:12px;padding:9px;border-radius:8px;border:2px solid #ccc;font-size:13px}textarea{height:78vh;resize:none;font-family:Consolas,monospace;background:white}.slider-row{display:flex;gap:8px;align-items:center}.slider-row input[type="range"]{flex:1}.slider-row input[type="number"]{width:75px}input[type="range"]{accent-color:#09f;cursor:pointer}input[type="color"]{height:48px;border:0;cursor:pointer;background:0}.section h2,.canvas-title,.right-panel h2{position:relative;overflow:visible}.section h2:hover::after,.canvas-title:hover::after,.right-panel h2:hover::after{content:attr(data-tooltip);position:absolute;left:50%;top:110%;transform:translateX(-50%);width:clamp(140px,22vw,320px);max-width:85vw;padding:clamp(6px,1vw,14px);border-radius:clamp(10px,1vw,18px);background:linear-gradient(135deg,#ffecb3,#ffd6e7,#d9f7ff);color:#333;font-size:clamp(10px,0.9vw,14px);font-weight:bold;line-height:1.4;text-align:center;font-family:"Comic Sans MS","Trebuchet MS",sans-serif;border:4px solid white;box-shadow:0 6px 14px rgba(0,0,0,0.18);z-index:999999;animation:tooltipFade .2s ease;word-wrap:break-word;overflow-wrap:break-word}.section h2:hover::before,.canvas-title:hover::before,.right-panel h2:hover::before{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border-width:10px;border-style:solid;border-color:transparent transparent white transparent;z-index:1000000}@keyframes tooltipFade{from{opacity:0;transform:translateX(-50%) translateY(-6px) scale(0.92)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}.code-mode-bar{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.code-mode-btn{flex:1;min-width:90px;padding:10px;border:0;border-radius:14px;background:linear-gradient(135deg,#ffb347,#ff6ec7);color:white;font-weight:bold;font-size:12px;cursor:pointer;transition:.3s;box-shadow:0 4px 10px rgba(0,0,0,0.15)}.code-mode-btn:hover{transform:scale(1.04)}.active-code-mode{background:linear-gradient(135deg,#00c6ff,#0072ff);box-shadow:0 0 12px rgba(0,114,255,0.4)}.disabled-code-mode{background:linear-gradient(135deg,#ccc,#999);cursor:not-allowed;opacity:.8}.code-editor-wrapper{display:flex;width:100%;height:78vh;border-radius:18px;overflow:hidden;border:4px solid #ddd;background:white;box-shadow:0 4px 12px rgba(0,0,0,0.12);position:relative}.line-numbers{width:60px;min-width:60px;background:linear-gradient(180deg,#d9f7ff,#ffe0f7);color:#444;padding:14px 10px;text-align:right;font-family:Consolas,monospace;font-size:13px;line-height:1.7;overflow:hidden;border-right:3px solid #ddd;user-select:none;font-weight:bold;white-space:pre-line}#codeBox{flex:1;height:100%;border:0;outline:0;resize:none;padding:14px;font-family:Consolas,monospace;font-size:13px;line-height:1.7;background:#fffefc;color:#333;overflow:auto;white-space:pre;position:relative;z-index:3}@media(max-width:1100px){.app{grid-template-columns:minmax(190px,24vw) 1fr minmax(190px,24vw)}#turtleCanvas{width:min(100%,700px)}button{font-size:13px}}@media(max-width:850px){.app{grid-template-columns:minmax(170px,26vw) 1fr minmax(170px,26vw)}#turtleCanvas{width:min(100%,520px)}.section{padding:12px}button{padding:9px;font-size:12px}.slider-row{flex-direction:column;align-items:stretch}.slider-row input[type="number"]{width:100%}.code-mode-btn{font-size:11px;padding:8px}}@media(max-width:650px){.app{grid-template-columns:150px 1fr 150px}#turtleCanvas{width:min(100%,360px)}.left-panel,.right-panel{padding:8px}.section{padding:10px;margin-bottom:16px}.section h2,.right-panel h2{font-size:13px;padding:8px}button{font-size:11px;padding:8px}label{font-size:11px}input,select,textarea{font-size:11px;padding:6px}textarea{height:60vh}.logo-image{width:70px}.canvas-title{font-size:15px;padding:8px 12px}.line-numbers{width:42px;min-width:42px;font-size:10px;padding:10px 6px}#codeBox{font-size:11px}.code-mode-btn{font-size:10px;padding:7px}}@media(max-width:500px){.app{grid-template-columns:125px 1fr 125px}#turtleCanvas{width:min(100%,280px)}button{font-size:10px}.section h2,.right-panel h2{font-size:12px}.code-mode-btn{min-width:100%;font-size:10px}}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#eee}::-webkit-scrollbar-thumb{background:#bbb;border-radius:12px}::-webkit-scrollbar-thumb:hover{background:#999}.code-box{flex:1;height:100%;margin:0;overflow:auto;padding:14px;background:#fffefc;color:#333;font-family:Consolas,monospace;font-size:13px;line-height:1.7;white-space:pre-wrap;outline:0}.python-import{color:#f80;font-weight:bold}.python-keyword{color:#c94fff;font-weight:bold}.python-function{color:#07c;font-weight:bold}.python-string{color:#0b4;font-weight:bold}.python-number{color:#00d5ff;font-weight:bold}.python-comment{color:#ff4fc3;font-style:italic;font-weight:bold}.python-object{color:#07c;font-weight:bold}.python-class{color:#a3f;font-weight:bold}.canvas-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%}.canvasFooter{width:100%;margin-top:10px;text-align:center;font-size:12px;line-height:1.4;font-family:Consolas,monospace;color:gray;font-weight:700;padding-bottom:8px;white-space:nowrap;overflow-x:auto}.canvasFooter strong{color:#c94fff}.footerPhone{color:gray;font-weight:800}.divider{width:100%;height:4px;background:rgba(102,204,102,0.35);margin:18px 0;border-radius:12px;border:1px solid rgba(102,204,102,0.55);box-shadow:inset 0 1px 2px rgba(255,255,255,0.45);opacity:1}.active-replay-line{background:rgba(255,255,0,0.35);border-radius:6px;transition:.2s}#replayHighlight{position:absolute;left:60px;right:0;top:-100px;height:22px;background:rgba(255,255,0,0.25);border-radius:6px;pointer-events:none;transition:top .15s;z-index:2}