:root,[data-theme=dark]{--bg: #1e1e2e;--panel: rgba(24, 24, 37, .85);--panel-solid: #181825;--text: #cdd6f4;--text-muted: #bac2de;--border: rgba(255,255,255,.08);--border-strong: #45475a;--accent: #cba6f7;--accent-transparent: rgba(203, 166, 247, .15);--accent-glow: rgba(203, 166, 247, .4);--danger: #f38ba8}[data-theme=light]{--bg: #f5f5f5;--panel: rgba(255, 255, 255, .85);--panel-solid: #ffffff;--text: #111111;--text-muted: #666666;--border: rgba(0,0,0,.1);--border-strong: #cccccc;--accent: #8839ef;--accent-transparent: rgba(136, 57, 239, .15);--accent-glow: rgba(136, 57, 239, .4);--danger: #d20f39}*{transition:background .25s ease,color .25s ease,border-color .25s ease,box-shadow .25s ease}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;display:flex;min-width:320px;min-height:100vh;overflow:hidden}#root{width:100vw;height:100vh;display:flex;flex-direction:column}.no-select{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.landing-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;gap:2rem}.landing-container h1{font-size:3rem;background:-webkit-linear-gradient(45deg,#f38ba8,var(--accent));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.room-form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:300px}.room-form input{padding:.8rem;border-radius:8px;border:1px solid var(--border-strong);background:var(--panel-solid);color:var(--text);font-size:1rem;outline:none;transition:border-color .2s cubic-bezier(.4,0,.2,1)}.room-form input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #cba6f733}.room-form button{padding:.8rem;border-radius:8px;border:none;background:var(--accent);color:#11111b;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s cubic-bezier(.4,0,.2,1)}.room-form button:hover{opacity:.9}.room-form button:active{transform:scale(.96)}.room-container{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.whiteboard-wrapper{flex-grow:1;position:relative;background-color:var(--bg);width:100vw;height:100vh}canvas{display:block;width:100%;height:100%;position:absolute;top:0;left:0;z-index:10;outline:none;-webkit-tap-highlight-color:transparent}canvas.tool-line,canvas.tool-rectangle,canvas.tool-circle,canvas.tool-ellipse,canvas.tool-arrow,canvas.tool-triangle,canvas.tool-diamond{cursor:crosshair}canvas.tool-text{cursor:text}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}canvas.tool-select{cursor:grab}canvas.tool-select.grabbing{cursor:grabbing}canvas.tool-hand{cursor:grab}canvas.tool-hand.grabbing{cursor:grabbing}canvas.tool-eraser{cursor:url('data:image/svg+xml;utf8,<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M2.586 15.414l4 4a2 2 0 002.828 0l12-12a2 2 0 000-2.828l-4-4a2 2 0 00-2.828 0l-12 12a2 2 0 000 2.828z" fill="%23cba6f7" stroke="%231e1e2e" stroke-width="2"/><path d="M12 19h9" stroke="%23cba6f7" stroke-width="2" stroke-linecap="round"/></svg>') 0 24,auto}.excalidraw-top-bar,.excalidraw-left-panel,.excalidraw-bottom-panel{background:var(--panel);backdrop-filter:blur(24px) saturate(150%);-webkit-backdrop-filter:blur(24px) saturate(150%);border:1px solid var(--border);box-shadow:0 12px 32px #00000040,0 2px 6px #0000001a;border-radius:14px;z-index:50}.excalidraw-top-bar{position:absolute;top:1.5rem;left:50%;transform:translate(-50%);display:flex;flex-direction:row;align-items:center;padding:.5rem .6rem;overflow-x:auto;max-width:90vw;scrollbar-width:none;transition:transform .3s ease}.excalidraw-top-bar::-webkit-scrollbar{display:none}.excalidraw-left-panel{position:absolute;top:5.5rem;left:1.5rem;display:flex;flex-direction:column;padding:.8rem;gap:.8rem;width:220px;max-height:calc(100vh - 120px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(203,166,247,.3) transparent}.excalidraw-bottom-panel{position:absolute;bottom:1.5rem;left:1.5rem;display:flex;padding:6px;gap:6px;align-items:center}.tool-group-horizontal{display:flex;flex-direction:row;align-items:center;gap:.25rem;flex-wrap:nowrap}.separator-vertical{width:1px;height:24px;background-color:var(--border);margin:0 .5rem;flex-shrink:0;border-radius:1px}.tool-btn{width:40px;height:40px;border-radius:10px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;align-items:center;transition:all .2s cubic-bezier(.25,.46,.45,.94);position:relative}.tool-btn:hover{background:#ffffff0f;color:var(--text)}.tool-btn:active{transform:scale(.92)}.tool-btn.active{background:var(--accent-transparent);box-shadow:inset 0 0 0 1px var(--accent-glow);color:var(--accent)}.danger-btn:hover{background:#f38ba826;color:#f38ba8}.danger-btn:hover svg{stroke:#f38ba8}.shapes-group{position:relative}.shape-expand-btn{height:24px}.shape-expand-btn svg{transition:transform .2s cubic-bezier(.4,0,.2,1)}.shape-expand-btn.active svg{transform:rotate(90deg)}.shapes-popout{position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%) scale(.95);background:var(--panel);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:.5rem;border-radius:12px;border:1px solid var(--border);box-shadow:0 12px 32px #0000004d;opacity:0;visibility:hidden;transition:all .25s cubic-bezier(.16,1,.3,1);pointer-events:none;z-index:60}.shapes-popout.visible{opacity:1;visibility:visible;transform:translateY(-50%) scale(1);pointer-events:auto}.popout-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.25rem}.properties-section{display:flex;flex-direction:column;gap:.75rem;width:100%;padding:.25rem 0;scrollbar-width:thin;scrollbar-color:rgba(203,166,247,.5) transparent}.properties-section::-webkit-scrollbar{width:4px}.properties-section::-webkit-scrollbar-track{background:transparent}.properties-section::-webkit-scrollbar-thumb{background:#cba6f74d;border-radius:4px}.properties-section:hover::-webkit-scrollbar-thumb{background:#cba6f799}.color-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;padding:0 .2rem;width:100%}.color-btn{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease;margin:auto;box-shadow:inset 0 2px 4px #00000026;position:relative}.color-btn:hover{transform:scale(1.2);box-shadow:inset 0 2px 4px #00000026,0 4px 8px #0003}.color-btn.active{border-color:var(--bg);transform:scale(1.25);box-shadow:0 0 0 2px var(--text),0 4px 8px #0003;z-index:2}.size-grid{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;gap:.2rem;align-items:center}.stroke-btn{flex:1;height:32px;padding:0 10px;border-radius:8px;border:none;background:transparent;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:all .15s ease}.stroke-btn:hover{background:#ffffff0f}.stroke-btn.active{background:#cdd6f426;box-shadow:0 0 0 1px #cdd6f433}.stroke-btn:active{transform:translateY(1px)}.stroke-dot{background-color:#a6adc8;border-radius:50%;transition:all .15s ease}.stroke-btn.active .stroke-dot{background-color:var(--text);box-shadow:0 0 4px #cdd6f480}.scroll-back-wrapper{position:fixed;bottom:20px;right:20px;z-index:100;animation:fadeIn .25s ease}.scroll-back-btn{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;background:var(--panel);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);color:var(--text);font-size:.9rem;font-weight:500;cursor:pointer;box-shadow:0 8px 20px #00000040;transition:all .2s ease}.scroll-back-btn:hover{background:var(--accent-transparent);color:var(--accent);border-color:var(--accent-glow)}.scroll-back-btn:active{transform:scale(.96)}@media(max-width:600px){.scroll-back-wrapper{bottom:16px;right:16px}.scroll-back-btn{padding:8px 10px;font-size:.8rem}.scroll-back-btn span{display:none}}.export-modal-overlay{position:fixed;inset:0;background:#11111b99;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.export-modal-content{background:var(--bg);border:1px solid var(--border);border-radius:16px;width:100%;max-width:400px;box-shadow:0 12px 40px #0006;display:flex;flex-direction:column;animation:scaleUp .2s cubic-bezier(.16,1,.3,1)}@keyframes scaleUp{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.export-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.05)}.export-header h2{font-size:18px;font-weight:600;color:var(--text)}.export-close{background:transparent;border:none;color:#a6adc8;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.export-close:hover{background:var(--border);color:#f38ba8}.export-body{padding:24px;display:flex;flex-direction:column;gap:20px}.export-group{display:flex;flex-direction:column;gap:8px}.export-group label{font-size:13px;color:var(--text-muted);font-weight:500}.export-input{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s}.export-input:focus{border-color:var(--accent)}.export-formats{display:flex;gap:8px}.format-radio{flex:1;display:flex;align-items:center;justify-content:center;padding:10px;background:#ffffff08;border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;color:#a6adc8;transition:all .2s}.format-radio input{display:none}.format-radio.active{background:var(--accent-transparent);border-color:var(--accent);color:var(--accent)}.export-options{display:flex;flex-direction:column;gap:12px;background:#0003;padding:16px;border-radius:8px}.export-checkbox{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text);cursor:pointer}.export-checkbox input{cursor:pointer;accent-color:var(--accent);width:16px;height:16px}.export-preview{display:flex;align-items:center;gap:12px;padding:16px;background:#ffffff05;border-radius:8px;border:1px dashed var(--border);color:#a6adc8;font-size:14px;font-weight:500}.export-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid rgba(255,255,255,.05)}.export-btn-cancel{padding:10px 16px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.export-btn-cancel:hover{background:#ffffff0d;color:var(--text)}.export-btn-submit{padding:10px 20px;border-radius:8px;border:none;background:var(--accent);color:#11111b;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.export-btn-submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.export-btn-submit:active:not(:disabled){transform:translateY(0)}.export-btn-submit:disabled{background:var(--border);color:#ffffff4d;cursor:not-allowed}.side-toggles-container{position:fixed;right:16px;top:72px;display:flex;flex-direction:row;align-items:center;gap:8px;z-index:300;pointer-events:none}.chat-toggle-btn,.users-toggle-btn{pointer-events:auto;position:relative;width:42px;height:42px;flex-shrink:0;border-radius:12px;border:1px solid var(--border);background:#181825eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 14px #0000004d;transition:background .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1)}.chat-toggle-btn:not(.active):hover,.users-toggle-btn:not(.active):hover{background:var(--accent-transparent);color:var(--accent);border-color:#cba6f74d;transform:translateY(-2px);box-shadow:0 6px 18px #00000059}.chat-toggle-btn.active,.users-toggle-btn.active{background:var(--accent);color:#11111b;border-color:var(--accent);transform:translateY(0);box-shadow:0 4px 14px #cba6f759}.chat-toggle-btn:active,.users-toggle-btn:active{transform:scale(.93)}.chat-unread-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:#f38ba8;border:2px solid var(--bg);pointer-events:none}.user-count-badge{position:absolute;top:-5px;right:-5px;background:#a6e3a1;color:#11111b;font-size:10px;font-weight:800;height:18px;min-width:18px;padding:0 4px;border-radius:10px;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg);pointer-events:none}@media(max-width:600px){.side-toggles-container{top:auto;bottom:20px;right:50%;transform:translate(50%);background:var(--panel);padding:8px;gap:6px;border-radius:20px;border:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}}.user-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:8px;background:#18182599;border:1px solid rgba(255,255,255,.05);transition:background .1s ease}.user-item:hover{background:#313244cc}.user-item .avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.user-item .user-name{color:var(--text);flex:1}.user-item .user-you{color:#a6adc8;font-size:.85em;font-style:italic}.participants-count{background:#141420b3;color:var(--text);border-radius:12px;padding:2px 8px;font-size:.85em}.chat-container{position:fixed;top:130px;right:16px;width:300px;height:calc(100vh - 160px);z-index:400;display:flex;flex-direction:column;background:var(--panel);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:14px;border:1px solid var(--border);box-shadow:0 12px 32px #00000059}@keyframes chatSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.chat-header{flex-shrink:0;height:52px;padding:0 12px 0 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.07);background:#141420b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chat-header-left{display:flex;align-items:center;gap:8px}.chat-header-icon{color:var(--accent);flex-shrink:0}.chat-header h3{font-size:14px;font-weight:600;color:var(--text);letter-spacing:.01em;white-space:nowrap}.chat-close-btn{flex-shrink:0;width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:#ffffff0a;color:#a6adc8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease,border-color .15s ease}.chat-close-btn:hover{background:#f38ba824;color:#f38ba8;border-color:#f38ba84d}.chat-messages{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:14px 12px 8px;display:flex;flex-direction:column;gap:6px;scrollbar-width:thin;scrollbar-color:rgba(203,166,247,.2) transparent}.chat-messages::-webkit-scrollbar{width:3px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#cba6f733;border-radius:4px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#cba6f773}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;color:#6c7086;font-size:13px;line-height:1.6;padding:32px 24px;margin:auto 0}.chat-message{max-width:80%;min-width:0;display:flex;flex-direction:column;gap:2px}.chat-message.own{align-self:flex-end;align-items:flex-end}.chat-message.other{align-self:flex-start;align-items:flex-start}.chat-message.grouped{margin-top:-2px}.chat-message-name{font-size:11px;font-weight:600;color:#89b4fa;padding:0 4px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-message-bubble{font-size:13.5px;line-height:1.55;padding:8px 12px;border-radius:14px;word-break:break-word;overflow-wrap:break-word;white-space:pre-wrap;max-width:100%}.chat-message.own .chat-message-bubble{background:var(--accent);color:#11111b;border-bottom-right-radius:4px}.chat-message.other .chat-message-bubble{background:#2a2a3e;color:var(--text);border-bottom-left-radius:4px;border:1px solid rgba(255,255,255,.05)}.chat-message-time{font-size:10px;color:#585b70;padding:0 4px;white-space:nowrap}.chat-input-area{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid rgba(255,255,255,.07);background:#14142080}.chat-input-area input{flex:1;min-width:0;padding:9px 12px;font-size:13.5px;font-family:inherit;line-height:1.4;border-radius:9px;border:1px solid rgba(255,255,255,.07);background:#2a2a3e;color:var(--text);transition:border-color .2s ease,box-shadow .2s ease}.chat-input-area input::placeholder{color:#585b70}.chat-input-area input:focus{outline:none;border-color:#cba6f773;box-shadow:0 0 0 2px #cba6f71a}.chat-send-btn{flex-shrink:0;width:36px;height:36px;border-radius:9px;border:none;background:var(--accent);color:#11111b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .15s ease,transform .15s ease}.chat-send-btn:hover:not(:disabled){opacity:.85;transform:scale(1.07)}.chat-send-btn:active:not(:disabled){transform:scale(.94)}.chat-send-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}@media(max-width:900px){.chat-container{width:280px}}@media(max-width:600px){.chat-container{width:100vw;left:0;right:0;top:56px;height:calc(100dvh - 56px);border-left:none;border-top:1px solid rgba(255,255,255,.07)}}.custom-color-wrapper{display:flex;align-items:center;gap:8px;padding:6px 8px;margin-top:6px;border-top:1px solid var(--border)}.color-picker-input{width:28px;height:28px;border:none;border-radius:6px;cursor:pointer;background:none;padding:0}.color-picker-input::-webkit-color-swatch{border-radius:6px;border:none}.color-picker-input::-webkit-color-swatch-wrapper{padding:0}.color-label{font-size:11px;color:#a6adc8;font-weight:600}
