@import url(https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600&family=DM+Mono:wght@400;500&display=swap);body{-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--bg:#f2f1ef;--surface:#fff;--surface-hover:#f6f5f3;--border:#e3e1dc;--border-mid:#ccc9c2;--text-primary:#1c1b1f;--text-secondary:#6b6880;--text-muted:#b0adc0;--accent:#5b50e8;--accent-light:#eeedff;--accent-glow:#5b50e820;--coral:#e05c5c;--coral-light:#fff0f0;--green:#38b66a;--radius-xs:5px;--radius-sm:8px;--radius-md:14px;--radius-lg:22px;--font-ui:"DM Sans",sans-serif;--font-mono:"DM Mono",monospace;--toolbar-h:60px;--sidebar-w:210px;--shadow-xs:0 1px 3px #0000000f;--shadow-sm:0 2px 10px #00000012;--shadow-md:0 8px 32px #0000001a}*,:after,:before{box-sizing:border-box;margin:0;padding:0}#root,body,html{height:100%;overflow:hidden;width:100%}body{-webkit-font-smoothing:antialiased;background:#f2f1ef;background:var(--bg);color:#1c1b1f;color:var(--text-primary);cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg width='24' height='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m5.5 3 13 7.5-6 2-2 6L5.5 3Z' stroke='%23fff' stroke-width='1.5'/%3E%3C/svg%3E") 6 4,auto;font-family:DM Sans,sans-serif;font-family:var(--font-ui)}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden;width:100vw}.toolbar{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #e3e1dc;border-bottom:1px solid var(--border);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-xs);display:flex;flex-shrink:0;gap:4px;height:60px;height:var(--toolbar-h);padding:0 16px;position:relative;z-index:100}.toolbar:before{border-right:1px solid #e3e1dc;border-right:1px solid var(--border);color:#1c1b1f;color:var(--text-primary);content:"SketchRoom";flex-shrink:0;font-size:.92rem;font-weight:600;letter-spacing:-.02em;margin-right:8px;padding-right:16px;white-space:nowrap}.toolbar input[type=color]{appearance:none;background:#fff;background:var(--surface);border:1.5px solid #ccc9c2;border:1.5px solid var(--border-mid);border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0;height:34px;margin-top:10px;padding:3px;transition:border-color .18s,box-shadow .18s;width:72px}.toolbar input[type=color]::-webkit-color-swatch-wrapper{border-radius:6px;border-radius:calc(var(--radius-sm) - 2px);padding:0}.toolbar input[type=color]::-webkit-color-swatch{border:none;border-radius:5px;border-radius:calc(var(--radius-sm) - 3px)}.toolbar input[type=color]::-moz-color-swatch{border:none;border-radius:5px;border-radius:calc(var(--radius-sm) - 3px)}.toolbar input[type=color]:focus,.toolbar input[type=color]:hover{border-color:#5b50e8;border-color:var(--accent);box-shadow:0 0 0 3px #5b50e820;box-shadow:0 0 0 3px var(--accent-glow)}.toolbar input[type=color]:focus{outline:none}.toolbar:after{color:#b0adc0;color:var(--text-muted);content:"";font-size:.6rem;font-weight:600;left:211px;letter-spacing:.06em;line-height:1;pointer-events:none;position:absolute;text-transform:uppercase;top:9px;white-space:nowrap}.toolbar input[type=color]{margin-right:12px}.toolbar input[type=range]{appearance:none;background:#e3e1dc;background:var(--border);border:none;border-radius:99px;cursor:pointer;flex-shrink:0;height:3px;outline:none;width:96px}.toolbar input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:#5b50e8;background:var(--accent);border:2px solid #fff;border:2px solid var(--surface);border-radius:50%;box-shadow:0 0 0 1.5px #5b50e8;box-shadow:0 0 0 1.5px var(--accent);cursor:pointer;height:14px;-webkit-transition:transform .15s,box-shadow .15s;transition:transform .15s,box-shadow .15s;width:14px}.toolbar input[type=range]::-webkit-slider-thumb:hover{box-shadow:0 0 0 4px #5b50e820;box-shadow:0 0 0 4px var(--accent-glow);transform:scale(1.3)}.toolbar input[type=range]::-moz-range-thumb{background:#5b50e8;background:var(--accent);border:2px solid #fff;border:2px solid var(--surface);border-radius:50%;cursor:pointer;height:13px;width:13px}.toolbar button{background:#0000;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-sm);color:#6b6880;color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-family:DM Sans,sans-serif;font-family:var(--font-ui);font-size:.82rem;font-weight:500;height:34px;letter-spacing:-.01em;padding:0 13px;transition:color .15s,background .15s,border-color .15s,transform .1s;white-space:nowrap}.toolbar button:hover{background:#f6f5f3;background:var(--surface-hover);border-color:#e3e1dc;border-color:var(--border);color:#1c1b1f;color:var(--text-primary)}.toolbar button:active{transform:scale(.96)}.toolbar button[style*="#ffaa88"]{background:#fff0f0!important;background:var(--coral-light)!important;border-color:#f5c6c6!important;color:#e05c5c!important;color:var(--coral)!important}.toolbar button[style*="#ffaa44"]{background:#eeedff!important;background:var(--accent-light)!important;border-color:#cccaff!important;color:#5b50e8!important;color:var(--accent)!important}.toolbar button[style*="#88ccff"]{background:#e6faf8!important;border-color:#b0e8e0!important;color:#2a9e8a!important}.toolbar button:last-child{color:#e05c5c;color:var(--coral);margin-left:auto}.toolbar button:last-child:hover{background:#fff0f0;background:var(--coral-light);border-color:#f5c6c6;color:#e05c5c;color:var(--coral)}.main-area{display:flex;flex:1 1;min-height:0;overflow:hidden}.sidebar{background:#fff;background:var(--surface);border-right:1px solid #e3e1dc;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;gap:10px;overflow-y:auto;padding:20px 14px;width:210px;width:var(--sidebar-w)}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-thumb{background:#e3e1dc;background:var(--border);border-radius:99px}.sidebar h3{border-bottom:1px solid #e3e1dc;border-bottom:1px solid var(--border);color:#b0adc0;color:var(--text-muted);font-size:.68rem;font-weight:600;letter-spacing:.08em;padding-bottom:10px;text-transform:uppercase}.user-list{display:flex;flex-direction:column;gap:2px;list-style:none}.user-list li{align-items:center;animation:slideIn .2s ease both;border-radius:8px;border-radius:var(--radius-sm);color:#1c1b1f;color:var(--text-primary);display:flex;font-size:.875rem;font-weight:400;gap:9px;padding:8px 10px;transition:background .15s}.user-list li:hover{background:#f6f5f3;background:var(--surface-hover)}@keyframes slideIn{0%{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}.user-list li:before{animation:livePulse 2.4s ease-in-out infinite;background:#38b66a;background:var(--green);border-radius:50%;content:"";flex-shrink:0;height:7px;width:7px}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.35}}.canvas-container{background-color:#f2f1ef;background-color:var(--bg);background-image:radial-gradient(circle,#ccc9c2 1px,#0000 0);background-image:radial-gradient(circle,var(--border-mid) 1px,#0000 1px);background-size:22px 22px;flex:1 1;overflow:hidden;position:relative}.canvas-container:before{background:#fff;box-shadow:0 8px 32px #0000001a,0 0 0 1px #e3e1dc;box-shadow:var(--shadow-md),0 0 0 1px var(--border);content:"";pointer-events:none;z-index:0}.canvas-container:before,.draw-canvas{border-radius:14px;border-radius:var(--radius-md);inset:14px;position:absolute}.draw-canvas{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg width='24' height='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m5.5 3 13 7.5-6 2-2 6L5.5 3Z' stroke='%23fff' stroke-width='1.5'/%3E%3C/svg%3E") 6 4,crosshair;display:block;height:calc(100% - 28px)!important;touch-action:none;width:calc(100% - 28px)!important;z-index:1}.modal-overlay{align-items:center;animation:fadeIn .22s ease;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#1c1b1f59;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.join-modal{animation:popIn .28s cubic-bezier(.34,1.56,.64,1);background:#fff;background:var(--surface);border:1px solid #e3e1dc;border:1px solid var(--border);border-radius:22px;border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000001a;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:14px;padding:36px 30px;width:340px}@keyframes popIn{0%{opacity:0;transform:scale(.93) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.join-modal h2{font-size:1.4rem;font-weight:600;letter-spacing:-.03em}.join-modal h2,.join-modal input{color:#1c1b1f;color:var(--text-primary)}.join-modal input{background:#f6f5f3;background:var(--surface-hover);border:1.5px solid #e3e1dc;border:1.5px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);font-family:DM Sans,sans-serif;font-family:var(--font-ui);font-size:.95rem;outline:none;padding:12px 14px;transition:border-color .18s,box-shadow .18s,background .18s;width:100%}.join-modal input::placeholder{color:#b0adc0;color:var(--text-muted)}.join-modal input:focus{background:#fff;background:var(--surface);border-color:#5b50e8;border-color:var(--accent);box-shadow:0 0 0 3px #5b50e820;box-shadow:0 0 0 3px var(--accent-glow)}.join-modal button{background:#5b50e8;background:var(--accent);border:none;border-radius:8px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:DM Sans,sans-serif;font-family:var(--font-ui);font-size:.9rem;font-weight:600;letter-spacing:-.01em;padding:12px;transition:background .18s,box-shadow .18s,transform .1s;width:100%}.join-modal button:hover{background:#4840d4;box-shadow:0 4px 18px #5b50e820;box-shadow:0 4px 18px var(--accent-glow)}.join-modal button:active{transform:scale(.97)}.toast{animation:toastIn .3s cubic-bezier(.34,1.56,.64,1);background:#1c1b1f;background:var(--text-primary);border-radius:99px;bottom:28px;box-shadow:0 2px 10px #00000012;box-shadow:var(--shadow-sm);color:#fff;font-size:.84rem;font-weight:500;left:50%;letter-spacing:-.01em;padding:10px 20px;pointer-events:none;position:fixed;transform:translateX(-50%);z-index:2000}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,14px)}to{opacity:1;transform:translate(-50%)}}.room-info{border-top:1px solid #e3e1dc;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;margin-top:auto;padding-top:14px}.room-id{color:#b0adc0;color:var(--text-muted);font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:.72rem;line-height:1.6;word-break:break-all}.copy-btn,.room-id strong{color:#6b6880;color:var(--text-secondary);font-weight:500}.copy-btn{background:#0000;border:2px solid #07ff17;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;font-family:DM Sans,sans-serif;font-family:var(--font-ui);font-size:.79rem;padding:8px 12px;text-align:center;transition:color .15s,background .15s,border-color .15s}.copy-btn:hover{background:#eeedff;background:var(--accent-light);border-color:#cccaff;color:#5b50e8;color:var(--accent)}.loading{align-items:center;background:#f2f1ef;background:var(--bg);color:#b0adc0;color:var(--text-muted);display:flex;font-size:.9rem;height:100vh;justify-content:center;letter-spacing:.04em;width:100vw}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#e3e1dc;background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#ccc9c2;background:var(--border-mid)}@media (max-width:640px){:root{--sidebar-w:0px}.sidebar,.toolbar:before{display:none}.toolbar:after{left:14px;top:8px}.toolbar>input[type=color]{margin-left:0;margin-top:10px}.toolbar input[type=range]{width:70px}.toolbar button{font-size:.78rem;padding:0 9px}.draw-canvas{height:calc(100% - 16px)!important;inset:8px;width:calc(100% - 16px)!important}.canvas-container:before{inset:8px}.join-modal{padding:26px 18px;width:calc(100vw - 32px)}}
/*# sourceMappingURL=main.cf5274c7.css.map*/