*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:none;overscroll-behavior:none;-webkit-user-select:none;user-select:none}body{display:flex;flex-direction:column;background:#f5f5f5}.top-bar{display:flex;gap:8px;padding:8px;background:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 4px #0000001a;z-index:10}.canvas-container{position:relative;flex:1;overflow:hidden;background:#fff}.canvas-layer{position:absolute;top:0;left:0;display:block;touch-action:none}.toolbar-container{position:fixed;bottom:0;left:0;right:0;z-index:10;transition:transform .3s ease;transform:translateY(0)}.toolbar-container.hidden{transform:translateY(calc(100% - 18px))}.toolbar-toggle{height:18px;background:linear-gradient(90deg,red,#ff7f00,#ff0,#0f0,#00f,#8b00ff,red);background-size:200% 100%;animation:rainbow-shift 8s linear infinite;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 -2px 8px #0003;user-select:none}.toolbar-toggle:active{opacity:.9}.toolbar-toggle span{font-size:12px;color:#fffffff2;text-shadow:0 1px 3px rgba(0,0,0,.6);user-select:none;pointer-events:none}@keyframes rainbow-shift{0%{background-position:0% 0%}to{background-position:200% 0%}}.toolbar{display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;padding:12px;background:#fff;box-shadow:0 -2px 4px #0000001a;align-items:center;justify-content:center}.tool-picker{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.tool-btn{min-width:50px;min-height:50px;padding:8px;font-size:24px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s}.tool-btn:active,.tool-btn.active{background:#4caf50;border-color:#4caf50;transform:scale(.95)}.size-picker{display:flex;gap:8px;align-items:center;justify-content:center}.size-label{font-size:14px;font-weight:700;color:#333}.size-select{min-height:50px;min-width:90px;padding:8px 32px 8px 12px;font-size:16px;font-weight:700;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath fill='%23333' d='M0 0l6 8 6-8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.size-select:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.eraser-btn{padding:4px}.eraser-icon{display:flex;align-items:center;justify-content:center;gap:1px;font-size:9px;font-weight:700}.eraser-body{background:linear-gradient(180deg,#ff9eb5,#ffb3c6,#ffc4d6);color:#c41e3a;padding:6px 4px;border-radius:3px;border:1px solid #333;letter-spacing:-.5px;line-height:1}.eraser-tip{width:6px;height:18px;background:linear-gradient(180deg,#e8e8e8,#f5f5f5);border:1px solid #333}.eraser-tip-left{border-radius:2px 0 0 2px;border-right:none}.eraser-tip-right{border-radius:0 2px 2px 0;border-left:none}.color-picker{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.color-btn{width:44px;height:44px;flex-shrink:0;border:3px solid transparent;border-radius:50%;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0003}.color-btn:active,.color-btn.active{border-color:#333;transform:scale(1.1)}.color-btn.rainbow{background:linear-gradient(135deg,red,orange,#ff0,green,#00f 60%,indigo,violet)}.shape-selector{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.shape-type-btn{min-width:50px;min-height:50px;padding:8px;font-size:24px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s}.shape-type-btn:active,.shape-type-btn.active{background:#9c27b0;border-color:#9c27b0;transform:scale(.95)}.pattern-selector{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;width:100%;overflow-x:auto}.pattern-btn{min-width:40px;max-width:40px;min-height:40px;max-height:40px;padding:4px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pattern-btn img{width:28px;height:28px;object-fit:contain}.pattern-btn:active,.pattern-btn.active{background:#ff5722;border-color:#ff5722;transform:scale(.95)}.bg-btn{min-width:44px;min-height:44px;padding:0;font-size:24px;border:3px solid transparent;border-radius:50%;background:#fff;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0003;display:flex;align-items:center;justify-content:center}.bg-btn:active{border-color:#333;transform:scale(1.1)}.btn{min-width:44px;min-height:44px;padding:8px 12px;font-size:20px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s}.btn:active{transform:scale(.95);background:#f0f0f0}.btn:disabled{opacity:.5;cursor:not-allowed}.confirm-dialog{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.dialog-content{background:#fff;padding:24px;border-radius:12px;max-width:400px;margin:20px;box-shadow:0 4px 12px #0000004d}.dialog-content p{font-size:18px;margin-bottom:20px;text-align:center}.dialog-buttons{display:flex;gap:12px;justify-content:center}.btn-primary{background:#4caf50;border-color:#4caf50;color:#fff}.btn-secondary{background:#999;border-color:#999;color:#fff}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);padding:12px 24px;background:#000c;color:#fff;border-radius:24px;font-size:16px;opacity:0;pointer-events:none;transition:opacity .3s;z-index:300}.toast.show{opacity:1}@media(max-width:600px){.tool-picker,.color-picker{gap:6px}.tool-btn,.bg-btn{min-width:44px;min-height:44px;font-size:20px}.color-btn{width:40px;height:40px}}
