body{margin:0;overflow:hidden;font-family:Inter,sans-serif;background-color:#111;color:#fff}canvas{display:block}#tools-panel{position:absolute;top:20px;left:20px;background-color:#fff;color:#000;border-radius:10px;border:1px solid rgba(0,0,0,.2);width:280px;max-height:calc(100vh - 40px);display:flex;flex-direction:column;overflow:hidden;transition:max-height .3s ease}@media (max-width: 768px){#tools-panel{position:fixed;top:10px;left:10px;right:10px;width:auto;max-width:none;max-height:60vh;z-index:100;box-shadow:0 4px 20px #0000004d}#tools-panel.collapsed{max-height:none}}#tools-header{justify-content:space-between;align-items:center;border-bottom:1px solid rgba(0,0,0,.1);background-color:#f8f9fa;border-radius:10px 10px 0 0;flex:0 0 auto}#tools-controls{display:flex;gap:10px}.header-btn{padding:5px 10px;font-size:12px;min-width:auto}.icon-btn{padding:4px;min-width:28px;height:28px;display:flex;align-items:center;justify-content:center}.icon-btn .material-icons{font-size:16px}.icon-btn:disabled .material-icons{opacity:.5}.toolbox{padding:10px 15px;display:flex;flex-direction:column;gap:10px}#tools-content{flex:1 1 auto;min-height:0;overflow-y:auto}.hidden{display:none!important}#tools-panel.collapsed #tools-content{display:none}#tools-content::-webkit-scrollbar{width:8px}#tools-content::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}#tools-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}#tools-content::-webkit-scrollbar-thumb:hover{background:#bbb}#user-greeting-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}#user-info{display:flex;align-items:center;gap:8px}#user-greeting{font-size:12px}.profile-picture{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid #ddd}.logout-btn{font-size:10px;padding:2px 6px;background-color:#f8f9fa;color:#6c757d;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background-color:#e9ecef;color:#495057;border-color:#adb5bd}button{background-color:#f5f5f5;color:#000;border:1px solid #ddd;padding:10px 15px;border-radius:5px;cursor:pointer}button .material-icons{font-size:18px;margin-right:6px;vertical-align:middle}#loadBtn,#exportBtn{white-space:nowrap}button:hover{background-color:#e9e9e9;box-shadow:0 2px 6px #00000026}button:disabled{background-color:#f9f9f9;color:#999;cursor:not-allowed;opacity:.6;box-shadow:none}button:disabled:hover{background-color:#f9f9f9;box-shadow:none}button.active{background-color:#e0e0e0;box-shadow:inset 0 2px 4px #0003}p{margin:0;font-size:12px;color:#666}.ui-section{border-top:1px solid rgba(0,0,0,.2);padding-top:15px}.ui-section.first-section{border-top:none;padding-top:0}.ui-section h3{margin:0 0 10px;font-size:14px;color:#000}h2{font-size:1.5em;margin:0 0 .2em;letter-spacing:2px}h2 span{font-weight:400;font-size:.8em}.ui-control{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-grow:1}.ui-group-horizontal{display:flex;align-items:center;gap:15px}.ui-group-horizontal .ui-control{min-width:0;flex-shrink:1}.ui-group-horizontal .ui-control label,.label{font-size:12px;white-space:nowrap}.ui-control label{font-size:13px}select{width:120px;background:#f5f5f5;color:#000;border:1px solid #ccc;border-radius:4px;padding:4px}input[type=range]{width:120px;-webkit-appearance:none;appearance:none;height:6px;background:#e0e0e0;border-radius:3px;outline:none;box-shadow:inset 0 1px 3px #0000001a}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#fff;border:2px solid #ddd;border-radius:50%;cursor:pointer;box-shadow:0 1px 2px #0000001a;transition:all .2s ease}input[type=range]::-webkit-slider-thumb:hover{border-color:#bbb;box-shadow:0 1px 3px #00000026;transform:scale(1.1)}input[type=range]::-webkit-slider-thumb:active{box-shadow:0 1px 2px #0003;transform:scale(1.05)}input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#fff;border:2px solid #ddd;border-radius:50%;cursor:pointer;box-shadow:0 1px 2px #0000001a;transition:all .2s ease}input[type=range]::-moz-range-thumb:hover{border-color:#bbb;box-shadow:0 1px 3px #00000026;transform:scale(1.1)}input[type=range]::-moz-range-track{height:6px;background:#e0e0e0;border-radius:3px;box-shadow:inset 0 1px 3px #0000001a}input[type=color]{width:120px;height:32px;background:#f5f5f5;border:1px solid #ccc;border-radius:4px;cursor:pointer}input[type=checkbox]{-webkit-appearance:none;appearance:none;width:38px;height:20px;background:#e0e0e0;border-radius:10px;outline:none;cursor:pointer;position:relative;transition:background-color .2s ease;box-shadow:inset 0 1px 3px #0000001a;flex-shrink:0}input[type=checkbox]:checked{background:#99c860}input[type=checkbox]:before{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .2s ease;box-shadow:0 1px 2px #0000001a}input[type=checkbox]:checked:before{transform:translate(18px)}input[type=checkbox]:hover:before{box-shadow:0 1px 3px #00000026}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background-color:#fff;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:15px;width:80%;max-width:800px;max-height:80vh;overflow:hidden;box-shadow:0 10px 30px #0000004d}@media (max-width: 768px){.modal-content{width:95%;max-width:none;max-height:90vh;border-radius:10px}.modal-header{padding:15px 20px}.modal-body{padding:20px}#presets-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:15px}.preset-item{padding:10px}.preset-image{width:120px;height:120px}.preset-name{font-size:12px}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #eee;background-color:#f8f9fa}.modal-header h2{margin:0;color:#333}.close{font-size:28px;font-weight:700;cursor:pointer;color:#999;transition:color .2s}.close:hover{color:#333}.modal-body{padding:25px;max-height:calc(80vh - 100px);overflow-y:auto}#presets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}.preset-item{display:flex;flex-direction:column;align-items:center;padding:15px;border:2px solid #eee;border-radius:10px;cursor:pointer;transition:all .2s ease;background:#fff}.preset-item:hover{border-color:#ddd;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.preset-item.selected{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.preset-image{width:140px;height:140px;border-radius:8px;overflow:hidden;margin-bottom:10px;background:#f8f9fa;display:flex;align-items:center;justify-content:center;border:1px solid #eee}.preset-image img{width:100%;height:100%;object-fit:cover}.new-preset-icon{font-size:48px;color:#999;font-weight:300}.preset-name{text-align:center;font-weight:500;color:#333;font-size:14px}@media (max-width: 480px){#tools-panel{top:5px;left:5px;right:5px;max-height:50vh}#tools-content{max-height:calc(50vh - 60px);padding:8px 12px;gap:8px}#tools-header{padding:8px 12px}#tools-header h2{font-size:14px}.header-btn{padding:4px 8px;font-size:11px}button{padding:8px 12px;font-size:13px}.ui-control{margin-bottom:6px}.ui-control label{font-size:12px}select,input[type=range]{width:100px}input[type=color]{width:100px;height:28px}.ui-section h3{font-size:13px;margin-bottom:8px}.ui-group-horizontal{gap:8px;align-items:stretch}.ui-group-horizontal .ui-control{margin-bottom:4px}#presets-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.preset-image{width:90px;height:90px}.new-preset-icon{font-size:32px}.preset-name{font-size:11px}}#handle-context-menu{position:absolute;display:none;background-color:#333;border:1px solid #555;border-radius:4px;padding:8px 0;min-width:150px;z-index:1000;color:#fff;font-size:14px;font-family:Arial,sans-serif;box-shadow:0 2px 10px #00000080}#handle-context-menu .menu-item{padding:8px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}#handle-context-menu .menu-item:hover{background-color:#555}#handle-color-picker{position:absolute;display:none;z-index:1000;width:5px;visibility:hidden;height:5px;border:none;cursor:pointer;border-radius:4px;box-shadow:0 2px 8px #0000004d}
