*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root,.app{height:100%;font-family:Arial,Helvetica,sans-serif;background:#f0f4f8;color:#1a202c;overflow:hidden}.app{display:flex;flex-direction:column}.toolbar{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#1a202c;color:#fff;flex-shrink:0;flex-wrap:wrap;min-height:48px;z-index:10}.toolbar-title{font-size:15px;font-weight:700;color:#90cdf4;white-space:nowrap;margin-right:4px}.toolbar-group{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.tb-btn{padding:5px 10px;border:1px solid #4a5568;border-radius:4px;background:#2d3748;color:#fff;cursor:pointer;font-size:12px;white-space:nowrap;transition:background .15s}.tb-btn:hover{background:#4a5568}.tb-btn.icon{padding:5px 9px;font-size:14px}.tb-btn.active{background:#3182ce;border-color:#63b3ed}.tb-btn.danger{background:#742a2a;border-color:#c53030}.tb-btn.danger:hover{background:#c53030}.zoom-label{font-size:12px;min-width:38px;text-align:center;color:#e2e8f0}.props-group{border-left:1px solid #4a5568;padding-left:8px}.tb-text-input{padding:4px 6px;border:1px solid #4a5568;border-radius:4px;background:#2d3748;color:#fff;font-size:12px;resize:none;width:130px}.tb-text-input.single{height:28px;resize:none}.tb-text-input::placeholder{color:#718096}.tb-select{padding:4px 6px;border:1px solid #4a5568;border-radius:4px;background:#2d3748;color:#fff;font-size:12px;cursor:pointer}.main-area{display:flex;flex:1;overflow:hidden}.palette{width:130px;flex-shrink:0;background:#2d3748;display:flex;flex-direction:column;align-items:center;padding:10px 6px;gap:6px;overflow-y:auto;border-right:2px solid #1a202c}.palette-title{color:#90cdf4;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding-bottom:4px;border-bottom:1px solid #4a5568;width:100%;text-align:center;margin-bottom:2px}.palette-item{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:grab;padding:6px;border-radius:6px;border:1px solid #4a5568;background:#1a202c;width:110px;transition:background .15s,border-color .15s}.palette-item:hover{background:#2c5282;border-color:#3182ce}.palette-item:active{cursor:grabbing}.palette-label{font-size:10px;color:#a0aec0;text-align:center}.palette-divider{height:1px;background:#4a5568;width:100%;margin:4px 0}.palette-hint{font-size:9px;color:#c7cfdc;line-height:1.7;padding:4px 2px}.canvas-wrapper{flex:1;position:relative;overflow:hidden;background:#edf2f7}.canvas-svg{width:100%;height:100%;display:block;cursor:default}.floating-editor{background:#fffffff7;border:2px solid #3182ce;border-radius:4px;padding:4px 6px;font-family:Arial,sans-serif;font-weight:400;color:#1a202c;outline:none;resize:none;box-shadow:0 4px 16px #00000040;min-width:80px;min-height:28px;line-height:1.3}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:2000;animation:modal-fade-in .12s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-box{background:#1e2736;border:1px solid #4a5568;border-radius:8px;padding:28px 32px 24px;min-width:340px;max-width:480px;box-shadow:0 20px 60px #00000080;animation:modal-slide-in .15s ease}@keyframes modal-slide-in{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{font-size:16px;font-weight:700;color:#e2e8f0;margin-bottom:10px}.modal-message{font-size:14px;color:#a0aec0;line-height:1.55;margin-bottom:24px}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.modal-btn{padding:8px 20px;border-radius:5px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .15s,border-color .15s}.modal-btn.primary{background:#3182ce;color:#fff;border-color:#3182ce}.modal-btn.primary:hover{background:#2b6cb0}.modal-btn.primary:focus{outline:2px solid #63b3ed;outline-offset:2px}.modal-btn.secondary{background:#2d3748;color:#e2e8f0;border-color:#4a5568}.modal-btn.secondary:hover{background:#4a5568}.ld-tab{position:fixed;right:0;top:50%;transform:translateY(-50%) translate(0);z-index:600;background:#3182ce;color:#fff;border:none;border-radius:6px 0 0 6px;padding:0;width:32px;height:110px;cursor:pointer;box-shadow:-2px 0 8px #0000004d;transition:background .15s,right .35s;display:flex;align-items:center;justify-content:center}.ld-tab:hover{background:#2b6cb0}.ld-tab--open{right:440px}.ld-tab-label{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);font-size:12px;font-weight:700;letter-spacing:1px;white-space:nowrap}.ld-drawer{position:fixed;top:0;right:0;width:440px;height:100%;background:#1a202c;border-left:2px solid #2d3748;z-index:500;display:flex;flex-direction:column;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 24px #0006}.ld-drawer--open{transform:translate(0)}.ld-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;background:#2d3748;border-bottom:1px solid #4a5568;flex-shrink:0}.ld-drawer-title{font-size:15px;font-weight:700;color:#90cdf4;letter-spacing:.3px}.ld-close-btn{background:none;border:none;color:#a0aec0;font-size:16px;cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1;transition:color .15s,background .15s}.ld-close-btn:hover{color:#fff;background:#4a5568}.ld-progress-bar-wrap{padding:10px 16px 8px;background:#2d3748;border-bottom:1px solid #4a5568;flex-shrink:0;display:flex;align-items:center;gap:10px}.ld-progress-bar-track{flex:1;height:7px;background:#4a5568;border-radius:4px;overflow:hidden}.ld-progress-bar-fill{height:100%;background:#48bb78;border-radius:4px;transition:width .4s ease}.ld-progress-label{font-size:11px;color:#a0aec0;white-space:nowrap}.ld-drawer-body{flex:1;overflow-y:auto;padding:8px 0 60px}.ld-drawer-body::-webkit-scrollbar{width:6px}.ld-drawer-body::-webkit-scrollbar-track{background:#1a202c}.ld-drawer-body::-webkit-scrollbar-thumb{background:#4a5568;border-radius:3px}.ld-module{margin-bottom:4px}.ld-module-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px 6px;background:#2d3748;border-top:1px solid #4a5568;border-bottom:1px solid #4a5568}.ld-module-title{font-size:12px;font-weight:700;color:#90cdf4;text-transform:uppercase;letter-spacing:.5px}.ld-module-count{font-size:11px;color:#718096;background:#1a202c;padding:1px 7px;border-radius:10px}.ld-module-count--done{color:#48bb78}.ld-item{border-bottom:1px solid #2d3748}.ld-item-header{width:100%;background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:8px;padding:10px 14px;text-align:left;color:#e2e8f0;transition:background .12s}.ld-item-header:hover{background:#2d3748}.ld-item--open>.ld-item-header{background:#2a3549}.ld-item-done-dot{font-size:13px;color:#718096;flex-shrink:0;width:16px}.ld-item--done>.ld-item-header .ld-item-done-dot{color:#48bb78}.ld-item-title{flex:1;font-size:13px;line-height:1.35}.ld-item--done>.ld-item-header .ld-item-title{color:#a0aec0;text-decoration:line-through;text-decoration-color:#4a5568}.ld-item-chevron{font-size:9px;color:#718096;flex-shrink:0}.ld-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;border-radius:8px;color:#fff;flex-shrink:0}.ld-item-body{padding:4px 16px 12px 38px;background:#171e2b;border-top:1px solid #2d3748}.ld-objective{font-size:13px;color:#bee3f8;background:#1e3a5f;border-left:3px solid #3182ce;padding:8px 10px;border-radius:0 4px 4px 0;margin-bottom:10px;line-height:1.45}.ld-para{font-size:13px;color:#cbd5e0;line-height:1.55;margin:8px 0}.ld-subheading{font-size:12px;font-weight:700;color:#90cdf4;text-transform:uppercase;letter-spacing:.5px;margin:12px 0 6px}.ld-tip{display:flex;gap:8px;align-items:flex-start;background:#2d3a1e;border:1px solid #3d5a22;border-radius:5px;padding:8px 10px;margin:10px 0;font-size:12px;color:#c6f6d5;line-height:1.5}.ld-tip-icon{flex-shrink:0}.ld-list{margin:6px 0 6px 4px;padding-left:16px;font-size:13px;color:#cbd5e0;line-height:1.65}.ld-list li{margin-bottom:3px}.ld-code-block{margin:10px 0;border-radius:5px;overflow:hidden;border:1px solid #4a5568}.ld-code-label{background:#2d3748;color:#90cdf4;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 10px}.ld-code{background:#0d1117;color:#a8d8a8;font-family:Courier New,Courier,monospace;font-size:11.5px;line-height:1.6;margin:0;padding:10px 12px;overflow-x:auto;white-space:pre}.ld-symbol-table{margin:8px 0;display:flex;flex-direction:column;gap:6px}.ld-symbol-row{display:flex;align-items:center;gap:10px;background:#2d3748;border-radius:5px;padding:6px 8px}.ld-symbol-svg{flex-shrink:0;background:#edf2f7;border-radius:3px}.ld-symbol-text{display:flex;flex-direction:column;gap:2px}.ld-symbol-text strong{font-size:11px;color:#e2e8f0}.ld-symbol-text span{font-size:11px;color:#a0aec0;line-height:1.4}.ld-hints{margin:10px 0 0}.ld-hints summary{font-size:12px;color:#90cdf4;cursor:pointer;padding:4px 0;-webkit-user-select:none;user-select:none}.ld-hints summary:hover{color:#bee3f8}.ld-hints[open] summary{margin-bottom:6px}.ld-item-footer{margin-top:12px;display:flex;justify-content:flex-end}.ld-done-btn{font-size:12px;font-weight:600;padding:6px 14px;border-radius:5px;border:1px solid #4a5568;background:#2d3748;color:#e2e8f0;cursor:pointer;transition:background .15s,border-color .15s}.ld-done-btn:hover{background:#4a5568}.ld-done-btn--done{background:#276749;border-color:#38a169;color:#c6f6d5}.ld-done-btn--done:hover{background:#22543d}@media print{.toolbar,.palette,.ld-drawer,.ld-tab{display:none!important}html,body,#root,.app{height:auto;overflow:visible;background:#fff}.main-area{display:block}.canvas-wrapper{width:100vw;height:100vh;overflow:visible;background:#fff}.canvas-svg{width:100%;height:100%}}
