*{-webkit-tap-highlight-color:transparent;box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;height:100vh;line-height:1.6;overflow:hidden;transition:background-color .3s ease}body,button,canvas,input,textarea{-webkit-user-select:none;user-select:none}.app.light-theme{background-color:#f5f5f5;color:#333}.app-header.light-theme{background-color:#fff;border-bottom:1px solid #e0e0e0;color:#2c3e50}.app.dark-theme{background-color:#1a1a1a;color:#ecf0f1}.app-header.dark-theme{background-color:#2c3e50;border-bottom:1px solid #34495e;color:#ecf0f1}.app{display:flex;flex-direction:column;height:100vh;margin:0;max-width:100%;padding:0;transition:background-color .3s ease}.app-header{border-bottom:1px solid #e0e0e0;box-shadow:0 2px 5px #0000000d;flex-shrink:0;padding:10px 20px;transition:all .3s ease;z-index:100}@media (max-width:768px){.app-header{padding:8px 12px;position:relative}}.toolbar.light-theme{background-color:#f8f9fa;color:#333}.toolbar.light-theme .tool-group{background-color:#e9ecef;border:1px solid #dee2e6}.toolbar.light-theme button{background-color:#dee2e6;border:1px solid #ced4da;color:#333}.toolbar.light-theme button:hover:not(:disabled):not(.active){background-color:#ced4da;transform:translateY(-2px)}.toolbar.light-theme button:disabled{opacity:.5}.toolbar.light-theme .color-preview{border-color:#adb5bd}.toolbar.dark-theme{background-color:#2c3e50;color:#ecf0f1}.toolbar.dark-theme .tool-group,.toolbar.dark-theme button{background-color:#34495e;border:1px solid #4a647b}.toolbar.dark-theme button{color:#ecf0f1}.toolbar.dark-theme button:hover:not(:disabled):not(.active){background-color:#3d566e;transform:translateY(-2px)}.toolbar.dark-theme button:disabled{opacity:.5}.toolbar.dark-theme .color-preview{border-color:#4a647b}.toolbar{border-radius:20px;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;padding:10px 0;position:relative;transition:background-color .3s ease;z-index:101}@media (max-width:768px){.toolbar{-webkit-overflow-scrolling:touch;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:50px;bottom:20px;box-shadow:0 4px 20px #00000026;flex-direction:row;gap:8px;left:50%;max-width:90vw;overflow-x:auto;padding:12px;position:fixed;transform:translateX(-50%)}.toolbar::-webkit-scrollbar{display:none}.tool-group{background:#0000;border:none;display:flex;gap:4px;padding:0}.toolbar button{background:#ffffffe6;border-radius:50%;box-shadow:0 2px 8px #0000001a;font-size:20px;height:48px;width:48px}}.tool-group{background-color:inherit;border-radius:20px;box-shadow:0 1px 3px #0000001a;gap:8px;padding:5px 10px;transition:all .3s ease}.tool-group,.toolbar button{align-items:center;display:flex}.toolbar button{background-color:#e9ecef;border:1px solid #dee2e6;border-radius:50%;cursor:pointer;font-size:18px;height:36px;justify-content:center;touch-action:manipulation;transition:all .2s;width:36px}.toolbar button:hover{background-color:#dde2e6;transform:translateY(-2px)}@media (max-width:768px){.toolbar button:hover{transform:none}}.toolbar button.active{background-color:#3498db;box-shadow:0 2px 4px #3498db4d;color:#fff;transform:scale(1.05)}@media (max-width:768px){.toolbar button.active{transform:scale(1.1)}}.toolbar button:disabled{background-color:#e9ecef;cursor:not-allowed;opacity:.5;transform:none}.color-picker{position:relative}.color-preview{background-color:#fff;border:2px solid #ddd;border-radius:50%;cursor:pointer;height:32px;transition:transform .2s;width:32px}@media (max-width:768px){.color-preview{height:40px;width:40px}}.color-preview:active{transform:scale(.9)}.color-picker input[type=color]{cursor:pointer;height:36px;left:0;opacity:0;position:absolute;top:0;width:36px;z-index:1}.width-slider{width:100px}@media (max-width:768px){.width-slider{width:80px}}.width-value{font-size:14px;min-width:40px;text-align:center}.canvas-area{display:flex;flex:1 1;flex-direction:column}.canvas-area,.canvas-container{overflow:hidden;position:relative}.canvas-container{background-color:#fff;flex:1 1;width:100%;z-index:100}.canvas-container.cursor-pen{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath fill='%23212121' d='M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04a.996.996 0 0 0 0-1.41l-2.34-2.34a.996.996 0 0 0-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z'/%3E%3C/svg%3E") 2 22,auto}.canvas-container.cursor-eraser{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath fill='%23D32F2F' d='M18.4 4.6c.38-.38.38-1 0-1.38-.38-.38-1-.38-1.38 0l-13 13c-.38.38-.38 1 0 1.38l3 3c.38.38 1 .38 1.38 0l13-13c.38-.38.38-1 0-1.38l-3-3V4.6Zm-1.5 2.49 3 3-11 11h-3l-1-4 11-11 1 1Z'/%3E%3C/svg%3E") 12 12,auto}.canvas-container.cursor-grab{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath fill='%231976D2' d='M12 3c-1.1 0-2 .9-2 2v6h4V5c0-1.1-.9-2-2-2m0 10c-1.1 0-2 .9-2 2v4h4v-4c0-1.1-.9-2-2-2m-8 0h4v6H4v-6m12 0h4v6h-4v-6M8 5h8v4.83c-.53-.54-1.23-.83-2-.83h-4c-.77 0-1.47.29-2 .83V5Z'/%3E%3C/svg%3E") 12 12,grab}.canvas-container.cursor-grabbing{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath fill='%231565C0' d='M12 3c-1.1 0-2 .9-2 2v6h4V5c0-1.1-.9-2-2-2m0 10c-1.1 0-2 .9-2 2v4h4v-4c0-1.1-.9-2-2-2m-8 0h4v6H4v-6m12 0h4v6h-4v-6M8 5h8v4.83c-.53-.54-1.23-.83-2-.83h-4c-.77 0-1.47.29-2 .83V5Z'/%3E%3C/svg%3E") 12 12,grabbing}.canvas-container.cursor-pointer{cursor:default}.canvas-container.cursor-line{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath fill='%233498db' d='m10 17 5-5-5-5v10z'/%3E%3C/svg%3E") 12 12,crosshair}.canvas-container.cursor-ns-resize{cursor:ns-resize}.canvas-container.cursor-ew-resize{cursor:ew-resize}.canvas-container.cursor-nwse-resize{cursor:nwse-resize}.canvas-container.cursor-nesw-resize{cursor:nesw-resize}.background-options{gap:8px;padding:4px 8px}.background-option{align-items:center;border:2px solid #0000;border-radius:50%;display:flex;height:36px;justify-content:center;padding:0;transition:all .2s;width:36px}@media (max-width:768px){.background-option{height:44px;width:44px}}.background-option.active{border-color:#3498db;transform:scale(1.1)}.background-preview{border-radius:50%;height:24px;width:24px}.grid-preview{background:#fff9f9;border:1px solid #e0e0e0;position:relative}.grid-preview:before{background-image:linear-gradient(90deg,#e0e0e0 1px,#0000 0),linear-gradient(180deg,#e0e0e0 1px,#0000 0);background-size:5px 5px;bottom:0;content:"";left:0;position:absolute;right:0;top:0}.black-preview{background:#000;border:1px solid #333}.shortcut{background-color:#f1f1f1;border:1px solid #ddd;border-radius:4px;font-weight:700;margin:0 3px;padding:2px 6px;transition:all .2s ease}.line-style-group{background-color:#3498db1a!important;border:1px solid #3498db4d}.line-style-group button{font-size:16px;height:30px;width:30px}.text-input-overlay{background:#0000;border:1px solid #3498db;color:inherit;font-family:Arial,sans-serif;font-size:16px;outline:none;overflow:auto;padding:4px;position:absolute;resize:both;z-index:1000}.canvas-container.cursor-text{cursor:text}.text-editor-overlay{background:#fff;border:2px solid #3498db;border-radius:4px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.canvas-container.cursor-text{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath fill='%233498db' d='M9 3h6v2H9zm0 16h6v2H9zm3-16a9 9 0 1 0 0 18 9 9 0 0 0 0-18zm0 4c1.1 0 2 .9 2 2s-.9 2-2 2-2-.9-2-2 .9-2 2-2zm0 10c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z'/%3E%3C/svg%3E") 12 12,text}.mobile-toolbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:25px;bottom:20px;box-shadow:0 4px 20px #00000026;left:50%;padding:12px;position:fixed;transform:translateX(-50%);z-index:1000}.mobile-toolbar-toggle{background:#3498db;border:none;border-radius:50%;box-shadow:0 2px 10px #0003;color:#fff;cursor:pointer;font-size:20px;height:50px;width:50px}.toolbar-content{display:flex;flex-direction:column;gap:10px;max-height:0;overflow:hidden;transition:max-height .3s ease}.toolbar-content.open{max-height:300px}.tool-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.tool-button-large{align-items:center;background:#ffffffe6;border:none;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;display:flex;flex-direction:column;font-size:24px;height:60px;justify-content:center;transition:transform .2s;width:60px}.tool-button-large:active{transform:scale(.95)}.tool-button-large span{font-size:10px;margin-top:4px}.context-menu{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;min-width:160px;padding:8px;position:absolute;z-index:1001}.context-menu button{background:none;border:none;border-radius:8px;cursor:pointer;display:block;font-size:16px;padding:12px 16px;text-align:left;transition:background-color .2s;width:100%}.context-menu button:hover{background-color:#f5f5f5}.swipe-indicator{animation:fadeInOut 3s ease-in-out;background:#000000b3;border-radius:20px;bottom:100px;color:#fff;font-size:12px;left:50%;padding:8px 16px;position:absolute;transform:translateX(-50%)}@keyframes fadeInOut{0%,to{opacity:0}50%{opacity:1}}.touch-feedback{animation:ripple .3s ease-out;background:#3498db4d;border-radius:50%;height:40px;pointer-events:none;position:absolute;width:40px;z-index:1000}@keyframes ripple{0%{opacity:1;transform:scale(0)}to{opacity:0;transform:scale(2)}}@media (max-width:768px){.canvas-area{height:calc(100vh - 60px)}.canvas-container{touch-action:none}}.quick-actions{display:flex;flex-direction:column;gap:12px;position:fixed;right:20px;top:20px;z-index:1000}.fab{background:#3498db;border:none;border-radius:50%;box-shadow:0 4px 12px #0003;color:#fff;cursor:pointer;font-size:20px;height:56px;transition:transform .2s,box-shadow .2s;width:56px}.fab:active{box-shadow:0 2px 8px #0000004d;transform:scale(.9)}.fab.danger{background:#e74c3c}.loading-overlay{align-items:center;background:#ffffffe6;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:1002}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.touch-preview{pointer-events:none;position:absolute;transition:all .1s ease;z-index:999}.collaborative-canvas{display:flex;flex-direction:column;height:100vh;position:relative}.collab-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;justify-content:space-between;padding:10px 20px}.collab-header,.room-info{align-items:center;display:flex}.room-info{gap:15px}.room-title{font-size:16px;font-weight:700}.connection-status{border-radius:12px;font-size:12px;padding:4px 8px}.connected{background:#4caf50}.connecting{background:#ff9800}.room-link-container{align-items:center;display:flex;gap:10px}.room-link-input{min-width:300px;padding:8px 12px}.copy-btn,.room-link-input{background:#fff3;border:none;border-radius:4px;color:#fff}.copy-btn{cursor:pointer;padding:8px 16px;transition:background .3s}.copy-btn:hover{background:#ffffff4d}.collab-toolbar{position:relative;z-index:1001}.canvas-container-wrapper{flex:1 1;overflow:hidden;position:relative}.peer-cursors{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:999}.peer-cursor{transition:all .1s ease}.cursor-pointer{position:absolute}.cursor-name{box-shadow:0 2px 4px #0003}@media (max-width:768px){.collab-header{flex-direction:column;gap:10px}.room-link-container{align-items:stretch;flex-direction:column}.room-link-input{min-width:auto}}
/*# sourceMappingURL=main.0246d78d.css.map*/