@font-face{font-family:Excalifont;src:url(/assets/Excalifont-Regular-C9eKQy_N.woff2) format("woff2");font-weight:400;font-style:normal}*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0;background-color:#f5f5f5}body.canvas-mode{overflow:hidden}#root{width:100%;min-height:100vh}#root.canvas-mode{width:100vw;height:100vh;overflow:hidden}.zoom-controls{position:fixed;bottom:20px;left:20px;display:flex;align-items:center;gap:4px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:6px;z-index:10000}.zoom-btn{background:transparent;border:none;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px;font-size:18px;font-weight:700;transition:background .2s}.zoom-btn:hover{background:#f5f5f5}.zoom-display{background:transparent;border:none;padding:6px 12px;font-size:13px;cursor:pointer;border-radius:4px;min-width:60px;transition:background .2s}.zoom-display:hover{background:#f5f5f5}.zoom-separator{width:1px;height:20px;background:#e0e0e0;margin:0 4px}.dark-mode .zoom-controls{background:#2d2d2d;color:#fff}.dark-mode .zoom-btn{color:#fff}.dark-mode .zoom-btn:hover{background:#3d3d3d}.dark-mode .zoom-display{color:#fff}.dark-mode .zoom-display:hover{background:#3d3d3d}.dark-mode .zoom-separator{background:#444}@media(max-width:768px){.zoom-controls{bottom:10px;left:10px;padding:8px;gap:6px}.zoom-btn{width:40px;height:40px;font-size:20px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.zoom-display{padding:8px 14px;font-size:14px;min-width:70px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.zoom-separator{height:24px;margin:0 2px}}@media(max-width:480px){.zoom-controls{bottom:8px;left:8px;padding:6px;gap:4px}.zoom-btn{width:36px;height:36px;font-size:18px}.zoom-display{padding:6px 10px;font-size:13px;min-width:60px}.zoom-separator{height:20px;margin:0}}@media(hover:none)and (pointer:coarse){.zoom-btn:hover,.zoom-display:hover{background:transparent}.zoom-btn:active{background:#f5f5f5;transform:scale(.95);transition:all .1s}.zoom-display:active{background:#f5f5f5;transform:scale(.98);transition:all .1s}.dark-mode .zoom-btn:hover,.dark-mode .zoom-display:hover{background:#2d2d2d}.dark-mode .zoom-btn:active,.dark-mode .zoom-display:active{background:#3d3d3d}}.menu-button-standalone{position:fixed;top:12px;left:20px;background:#fff;border:none;padding:8px;cursor:pointer;border-radius:8px;box-shadow:0 2px 8px #0000001a;z-index:10000;transition:background .2s;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.menu-button-standalone:hover{background:#f5f5f5}.top-toolbar{position:fixed;top:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:8px;z-index:10000;gap:8px}.toolbar-left{display:flex;align-items:center;gap:8px}.toolbar-right{display:flex;align-items:center}.menu-button,.lock-button,.library-button{background:transparent;border:none;padding:8px 12px;font-size:18px;cursor:pointer;border-radius:4px;transition:background .2s}.menu-button:hover,.lock-button:hover,.library-button:hover{background:#f5f5f5}.separator{width:1px;height:24px;background:#e0e0e0;margin:0 4px}.tools-container{display:flex;gap:4px}.tool-button{background:transparent;border:none;padding:8px;font-size:18px;cursor:pointer;border-radius:4px;transition:all .2s;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center}.tool-button:hover{background:#f5f5f5}.tool-button.active{background:#e3f2fd;color:#1976d2}.properties-panel{position:fixed;top:70px;left:50%;transform:translate(-50%);background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:12px;z-index:10000;display:flex;gap:16px;align-items:center}.property-item{display:flex;flex-direction:column;gap:6px}.property-item label{font-size:11px;color:#666;font-weight:500}.color-picker{width:36px;height:36px;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:2px}.color-picker:hover{border-color:#999}.transparent-btn{background:#fff;border:1px dashed #999;width:36px;height:36px;border-radius:4px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;margin-top:4px}.transparent-btn:hover{background:#f5f5f5}.stroke-options{display:flex;gap:4px}.stroke-btn{background:#fff;border:1px solid #ddd;width:36px;height:36px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px}.stroke-btn:hover{border-color:#999}.stroke-btn.active{background:#e3f2fd;border-color:#1976d2}.slider{width:120px;cursor:pointer}.dropdown-menu{position:fixed;top:60px;left:20px;background:#fff;border-radius:8px;box-shadow:0 2px 12px #00000026;padding:8px;z-index:10001;min-width:200px}.dropdown-menu button{width:100%;background:transparent;border:none;padding:10px 12px;text-align:left;cursor:pointer;border-radius:4px;font-size:14px;display:flex;align-items:center;gap:10px}.dropdown-menu button:hover{background:#f5f5f5}.dropdown-menu button svg{flex-shrink:0;width:18px;height:18px}.dropdown-menu button span:not(.shortcut){flex:1}.dropdown-menu .shortcut{font-size:12px;color:#999;margin-left:auto}.menu-separator{height:1px;background:#e0e0e0;margin:6px 0}.dark-mode .menu-button-standalone{background:#2d2d2d;color:#fff}.dark-mode .menu-button-standalone:hover{background:#3d3d3d}.dark-mode .top-toolbar{background:#2d2d2d;color:#fff}.dark-mode .tool-button:hover{background:#3d3d3d}.dark-mode .tool-button.active{background:#1e3a5f;color:#64b5f6}.dark-mode .dropdown-menu{background:#2d2d2d;color:#fff}.dark-mode .dropdown-menu button:hover{background:#3d3d3d}.dark-mode .dropdown-menu .shortcut{color:#888}.dark-mode .menu-separator,.dark-mode .separator{background:#444}.dark-mode .tool-button{color:#fff}.dark-mode .dropdown-menu button svg{color:#fff}.dark-mode .dropdown-menu button span{color:#fff}.collab-button{position:relative;background:#fff;border:1px solid #e0e0e0;border-radius:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;margin-left:12px}.collab-button:hover{background:#f5f5f5;border-color:silver}.collab-button.active{background:#e3f2fd;border-color:#5e9ef5;color:#1976d2}.participant-badge{position:absolute;top:-6px;right:-6px;background:#5e9ef5;color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.dark-mode .collab-button{background:#2d2d2d;border-color:#444;color:#fff}.dark-mode .collab-button:hover{background:#3d3d3d;border-color:#555}.dark-mode .collab-button.active{background:#1e3a5f;border-color:#64b5f6;color:#64b5f6}@media(max-width:768px){.menu-button-standalone{top:10px;left:10px;width:44px;height:44px;padding:10px;box-shadow:0 2px 12px #00000026;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.top-toolbar{top:64px;left:10px;transform:none;padding:6px;max-height:calc(100vh - 140px);overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none;flex-direction:column;width:auto}.top-toolbar::-webkit-scrollbar{display:none}.tools-container{gap:2px;flex-direction:column;flex-wrap:nowrap}.tool-button{min-width:42px;min-height:42px;padding:10px;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.tool-button svg{width:20px;height:20px}.dropdown-menu{top:10px;left:64px;right:auto;min-width:250px;max-width:calc(100vw - 80px);box-shadow:0 4px 20px #0003}.dropdown-menu button{padding:14px 12px;font-size:15px;gap:12px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.dropdown-menu button svg{width:20px;height:20px}.dropdown-menu .shortcut{display:none}.properties-panel{top:70px;left:10px;right:10px;transform:none;max-width:calc(100vw - 20px);flex-wrap:wrap;gap:12px;padding:10px}.property-item{flex:1;min-width:80px}.slider{width:100px}}@media(max-width:480px){.menu-button-standalone{top:8px;left:8px;width:40px;height:40px;padding:8px}.top-toolbar{top:58px;left:8px;transform:none;padding:4px;max-height:calc(100vh - 130px);gap:4px;flex-direction:column;width:auto}.tools-container{gap:1px;flex-direction:column}.tool-button{min-width:38px;min-height:38px;padding:8px}.tool-button svg{width:18px;height:18px}.dropdown-menu{top:8px;left:56px;right:auto;padding:6px;min-width:240px;max-width:calc(100vw - 70px)}.dropdown-menu button{padding:12px 10px;font-size:14px;gap:10px}.dropdown-menu button svg{width:18px;height:18px}.properties-panel{top:58px;left:8px;right:8px}.property-item{min-width:70px}.color-picker,.transparent-btn,.stroke-btn{width:32px;height:32px}.slider{width:80px}}@media(hover:none)and (pointer:coarse){.tool-button:hover,.menu-button-standalone:hover,.dropdown-menu button:hover{background:transparent}.tool-button:active,.menu-button-standalone:active{background:#f5f5f5;transform:scale(.95);transition:all .1s}.dropdown-menu button:active{background:#f5f5f5;transform:scale(.98);transition:all .1s}.dark-mode .tool-button:active,.dark-mode .menu-button-standalone:active,.dark-mode .dropdown-menu button:active{background:#3d3d3d}}@media(max-width:768px)and (orientation:landscape){.top-toolbar{top:56px;left:6px;max-height:calc(100vh - 70px)}.menu-button-standalone{top:6px;left:6px}.dropdown-menu{top:6px;left:56px;max-height:calc(100vh - 20px);overflow-y:auto}}.help-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s}.help-content{background:#fff;border-radius:12px;padding:32px;max-width:600px;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 8px 24px #0003;animation:slideUp .3s}.help-close{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:32px;cursor:pointer;color:#999;line-height:1;padding:0;width:32px;height:32px}.help-close:hover{color:#333}.help-content h2{margin:0 0 8px;font-size:28px;color:#333}.help-subtitle{margin:0 0 24px;color:#666;font-size:16px}.help-section{margin-bottom:28px}.help-section h3{margin:0 0 12px;font-size:18px;color:#444}.help-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.help-grid div{font-size:14px;color:#555}kbd{background:#f5f5f5;border:1px solid #ddd;border-radius:4px;padding:2px 8px;font-family:monospace;font-size:13px;font-weight:600;color:#333;box-shadow:0 1px 2px #0000001a}.help-section ul{margin:0;padding-left:20px}.help-section li{margin-bottom:8px;color:#555;font-size:14px;line-height:1.6}.help-btn{width:100%;background:#5e9ef5;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:8px}.help-btn:hover{background:#4a8de0}.dark-mode .help-content{background:#2d2d2d;color:#fff}.dark-mode .help-close{color:#aaa}.dark-mode .help-close:hover,.dark-mode .help-content h2{color:#fff}.dark-mode .help-subtitle{color:#aaa}.dark-mode .help-section h3{color:#e0e0e0}.dark-mode .help-grid div{color:#ccc}.dark-mode kbd{background:#3d3d3d;border-color:#555;color:#fff}.dark-mode .help-section li{color:#ccc}.style-panel{position:fixed;left:20px;top:70px;background:#fff;border-radius:8px;padding:8px;display:flex;flex-direction:column;gap:4px;box-shadow:0 2px 12px #00000014;z-index:10000}.style-icon-item{position:relative}.icon-button{width:40px;height:40px;background:#fff;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#1a1a1a;transition:all .15s ease}.icon-button:hover{background:#f5f5f5}.style-popup{position:absolute;left:56px;top:0;background:#fff;border-radius:12px;padding:16px;box-shadow:0 4px 20px #0000001f;min-width:200px;animation:slideIn .2s cubic-bezier(.16,1,.3,1);z-index:10001;pointer-events:auto}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.popup-label{font-size:13px;color:#1a1a1a;font-weight:600;margin-bottom:12px}.color-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.color-swatch{width:32px;height:32px;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;padding:0;position:relative}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{border-color:#1a1a1a;box-shadow:0 0 0 2px #fff,0 0 0 4px #1a1a1a}.color-swatch.transparent{background:#fff;border:2px solid #e0e0e0}.color-swatch.transparent.active{border-color:#1a1a1a}.width-options{display:flex;gap:8px}.width-btn{flex:1;height:40px;background:#f5f5f5;border:2px solid transparent;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.width-btn:hover{background:#e8e8e8}.width-btn.active{border-color:#1a1a1a;background:#fff}.width-line{width:100%;max-width:24px;background:#1a1a1a;border-radius:2px}.roughness-slider{width:100%;height:6px;background:#e0e0e0;border-radius:3px;outline:none;-webkit-appearance:none;cursor:pointer;margin:12px 0}.roughness-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:#1a1a1a;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0003;transition:transform .2s ease}.roughness-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.roughness-slider::-moz-range-thumb{width:18px;height:18px;background:#1a1a1a;border:none;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0003;transition:transform .2s ease}.roughness-slider::-moz-range-thumb:hover{transform:scale(1.2)}.slider-value{font-size:12px;color:#666;text-align:center;font-weight:500}.dark-mode .style-panel{background:#2d2d2d}.dark-mode .icon-button{background:#2d2d2d;color:#fff}.dark-mode .icon-button:hover{background:#3d3d3d}.dark-mode .style-popup{background:#2d2d2d;color:#fff}.dark-mode .popup-label{color:#fff}.dark-mode .color-swatch.active{border-color:#fff;box-shadow:0 0 0 2px #2d2d2d,0 0 0 4px #fff}.dark-mode .color-swatch.transparent{background:#1a1a1a;border-color:#444}.dark-mode .color-swatch.transparent.active{border-color:#fff}.dark-mode .width-btn{background:#3d3d3d}.dark-mode .width-btn:hover{background:#4d4d4d}.dark-mode .width-btn.active{border-color:#fff;background:#2d2d2d}.dark-mode .width-line{background:#fff}.dark-mode .roughness-slider{background:#444}.dark-mode .roughness-slider::-webkit-slider-thumb{background:#fff}.dark-mode .roughness-slider::-moz-range-thumb{background:#fff}.dark-mode .slider-value{color:#aaa}@media(max-width:768px){.style-panel{left:50%;transform:translate(-50%);top:10px;padding:6px;gap:6px;flex-direction:row;width:auto;max-width:calc(100vw - 80px);right:auto}.icon-button{width:44px;height:44px;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.style-popup{position:fixed;inset:50% auto auto 50%;transform:translate(-50%,-50%);min-width:280px;max-width:calc(100vw - 40px);padding:20px;box-shadow:0 8px 32px #00000040}.color-grid{grid-template-columns:repeat(5,1fr);gap:10px}.color-swatch{width:40px;height:40px}.width-btn{height:44px}.popup-label{font-size:14px;margin-bottom:14px}}@media(max-width:480px){.style-panel{left:50%;transform:translate(-50%);top:8px;padding:5px;gap:4px;flex-direction:row;width:auto;max-width:calc(100vw - 70px);right:auto}.icon-button{width:40px;height:40px}.style-popup{min-width:260px;max-width:calc(100vw - 32px);padding:18px}.color-grid{grid-template-columns:repeat(4,1fr);gap:8px}.color-swatch{width:36px;height:36px}.width-btn{height:40px}}@media(hover:none)and (pointer:coarse){.icon-button:hover{background:#fff}.icon-button:active{background:#f5f5f5;transform:scale(.95);transition:all .1s}.color-swatch:hover{transform:none}.color-swatch:active{transform:scale(.95);transition:transform .1s}.width-btn:hover{background:#f5f5f5}.width-btn:active{background:#e8e8e8;transform:scale(.98);transition:all .1s}.roughness-slider::-webkit-slider-thumb:hover{transform:none}.roughness-slider::-moz-range-thumb:hover{transform:none}.dark-mode .icon-button:hover{background:#2d2d2d}.dark-mode .icon-button:active,.dark-mode .width-btn:hover{background:#3d3d3d}.dark-mode .width-btn:active{background:#4d4d4d}}@media(max-width:768px)and (orientation:landscape){.style-panel{left:50%;transform:translate(-50%);top:6px;width:auto;max-width:calc(100vw - 70px)}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;padding:30px;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:450px;width:90%;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.dark-mode .modal{background:#2a2a2a;color:#fff}.modal h2{margin:0 0 25px;font-size:24px;font-weight:600;color:#333}.dark-mode .modal h2{color:#fff}.modal-info{margin:0 0 25px;padding:15px;background:#f5f5f5;border-radius:8px;color:#555;font-size:14px;line-height:1.5}.dark-mode .modal-info{background:#1e1e1e;color:#aaa}.modal-close{position:absolute;top:15px;right:15px;background:none;border:none;font-size:28px;cursor:pointer;color:#666;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#0000000d;color:#333}.dark-mode .modal-close{color:#aaa}.dark-mode .modal-close:hover{background:#ffffff1a;color:#fff}.modal-section{margin-bottom:20px}.modal-section label{display:block;margin-bottom:8px;font-weight:500;color:#555;font-size:14px}.dark-mode .modal-section label{color:#ccc}.modal-section input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .2s;box-sizing:border-box}.modal-section input:focus{outline:none;border-color:#5e9ef5}.dark-mode .modal-section input{background:#1e1e1e;border-color:#444;color:#fff}.dark-mode .modal-section input:focus{border-color:#64b5f6}.input-hint{display:block;margin-top:6px;font-size:12px;color:#888}.dark-mode .input-hint{color:#666}.error-message{background:#ffebee;color:#c62828;padding:10px 12px;border-radius:6px;margin-bottom:15px;font-size:14px;border-left:3px solid #c62828}.dark-mode .error-message{background:#4a1f1f;color:#ff6b6b;border-left-color:#ff6b6b}.btn{width:100%;padding:14px 20px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#5e9ef5;color:#fff}.btn-primary:hover:not(:disabled){background:#4a8be0;transform:translateY(-1px);box-shadow:0 4px 12px #5e9ef54d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover:not(:disabled){background:#d0d0d0;transform:translateY(-1px)}.dark-mode .btn-secondary{background:#444;color:#fff}.dark-mode .btn-secondary:hover:not(:disabled){background:#555}.separator{display:flex;align-items:center;text-align:center;margin:25px 0;color:#999;font-size:12px;font-weight:500}.separator:before,.separator:after{content:"";flex:1;border-bottom:1px solid #e0e0e0}.dark-mode .separator:before,.dark-mode .separator:after{border-bottom-color:#444}.separator span{padding:0 15px}.participants-sidebar{position:fixed;right:0;top:60px;bottom:0;width:320px;background:#fff;border-left:1px solid #e0e0e0;border-radius:12px 0 0 12px;box-shadow:-2px 0 8px #00000014;display:flex;flex-direction:column;z-index:1000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.dark-mode .participants-sidebar{background:#2a2a2a;border-left-color:#444}.participants-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e0e0e0}.dark-mode .participants-header{border-bottom-color:#444}.header-title{display:flex;align-items:center;gap:12px}.header-title svg{flex-shrink:0;opacity:.7}.dark-mode .header-title svg{stroke:#aaa}.participants-header h3{margin:0;font-size:16px;font-weight:600;color:#333}.dark-mode .participants-header h3{color:#fff}.participant-count{background:#f5f5f5;color:#666;font-size:12px;font-weight:600;padding:2px 8px;border-radius:12px}.dark-mode .participant-count{background:#1e1e1e;color:#aaa}.close-btn{background:none;border:none;cursor:pointer;color:#666;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;flex-shrink:0}.close-btn:hover{background:#0000000d;color:#333}.dark-mode .close-btn{color:#aaa}.dark-mode .close-btn:hover{background:#ffffff1a;color:#fff}.participants-list{flex:1;overflow-y:auto;padding:16px}.participant-item{display:flex;align-items:center;gap:12px;padding:12px;margin-bottom:8px;border-radius:8px;background:#f9f9f9;border:1px solid #f0f0f0;transition:all .2s}.dark-mode .participant-item{background:#1e1e1e;border-color:#333}.participant-item:hover{background:#f0f0f0;border-color:#e0e0e0}.dark-mode .participant-item:hover{background:#2e2e2e;border-color:#444}.participant-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 4px #0000001a}.participant-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.participant-name{font-size:14px;color:#333;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark-mode .participant-name{color:#fff}.you-badge{display:inline-block;font-size:11px;color:#5e9ef5;background:#5e9ef51a;padding:2px 6px;border-radius:4px;font-weight:600;width:fit-content}.dark-mode .you-badge{color:#64b5f6;background:#64b5f626}.participant-status{flex-shrink:0}.online-indicator{width:8px;height:8px;border-radius:50%;background:#4caf50;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.share-section{padding:16px;border-top:1px solid #e0e0e0;background:#fafafa;display:flex;flex-direction:column;gap:10px}.dark-mode .share-section{border-top-color:#444;background:#1a1a1a}.copy-link-btn{width:100%;padding:12px 16px;background:#5e9ef5;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.copy-link-btn:hover{background:#4a8be0;transform:translateY(-1px);box-shadow:0 2px 8px #5e9ef54d}.copy-link-btn:active{transform:translateY(0)}.dark-mode .copy-link-btn{background:#4a8be0}.dark-mode .copy-link-btn:hover{background:#5e9ef5}.disconnect-btn{width:100%;padding:12px 16px;background:transparent;color:#f44336;border:1px solid #f44336;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.disconnect-btn:hover{background:#f44336;color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #f443364d}.disconnect-btn:active{transform:translateY(0)}.dark-mode .disconnect-btn{color:#ff5252;border-color:#ff5252}.dark-mode .disconnect-btn:hover{background:#ff5252;color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.app{width:100vw;height:100vh;overflow:hidden;position:relative;background-color:#fff;transition:background-color .3s ease}.app.dark-mode{background-color:#1e1e1e}canvas{display:block;width:100%;height:100%}.landing-page{min-height:100vh;background:#fafafa;color:#333;overflow-x:hidden;position:relative;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.landing-page:before{content:"";position:fixed;inset:0;background-image:linear-gradient(rgba(200,200,200,.15) 1px,transparent 1px),linear-gradient(90deg,rgba(200,200,200,.15) 1px,transparent 1px);background-size:20px 20px;pointer-events:none;z-index:0}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:80px 20px;opacity:0;transform:translateY(30px);transition:all .8s cubic-bezier(.4,0,.2,1)}.hero.visible{opacity:1;transform:translateY(0)}.hero-content{max-width:800px;text-align:center;position:relative;z-index:2}.logo-container{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:32px;animation:fadeInDown .8s ease-out}.logo-animated{width:80px;height:80px;background:#5e9ef5;border-radius:20px;display:flex;align-items:center;justify-content:center;border:2px solid rgba(94,158,245,.3);animation:float 3s ease-in-out infinite;box-shadow:0 8px 24px #5e9ef540}.logo-animated svg{color:#fff;width:52px;height:52px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.brand-name{font-size:48px;font-weight:700;margin:0;color:#5e9ef5;animation:fadeInDown .8s ease-out .2s backwards}.hero-title{font-size:64px;font-weight:800;line-height:1.2;margin:24px 0;color:#1a1a1a;animation:fadeInUp .8s ease-out .3s backwards}.hero-title .highlight{color:#5e9ef5;position:relative}.hero-description{font-size:20px;line-height:1.6;margin:32px 0;color:#555;animation:fadeInUp .8s ease-out .4s backwards}.cta-buttons{margin:48px 0;animation:fadeInUp .8s ease-out .5s backwards}.btn-primary{background:#5e9ef5;color:#fff;border:none;padding:18px 36px;font-size:18px;font-weight:600;border-radius:12px;cursor:pointer;display:inline-flex;align-items:center;gap:12px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px #5e9ef540;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn-primary:hover{transform:translateY(-4px);box-shadow:0 12px 32px #5e9ef559;background:#4a8be0}.btn-primary:active{transform:translateY(-2px)}.btn-primary.large{padding:22px 44px;font-size:20px}.hero-info{display:flex;justify-content:center;gap:32px;margin-top:48px;flex-wrap:wrap;animation:fadeInUp .8s ease-out .6s backwards}.info-item{display:flex;align-items:center;gap:8px;font-size:16px;color:#555}.info-item svg{flex-shrink:0;color:#5e9ef5}.shapes-container{position:absolute;inset:0;overflow:hidden;pointer-events:none}.shape{position:absolute;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;background:#5e9ef50d;border:2px solid rgba(94,158,245,.1)}.shape-1{width:400px;height:400px;top:10%;left:-100px;animation:float 6s ease-in-out infinite,rotate 20s linear infinite}.shape-2{width:300px;height:300px;bottom:10%;right:-50px;animation:float 8s ease-in-out infinite reverse,rotate 15s linear infinite reverse}.shape-3{width:200px;height:200px;top:60%;left:10%;animation:float 7s ease-in-out infinite,rotate 25s linear infinite}.shape-4{width:250px;height:250px;top:20%;right:15%;animation:float 9s ease-in-out infinite reverse,rotate 18s linear infinite reverse}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.features{padding:120px 20px;background:#fff;color:#333;position:relative;z-index:1}.section-title{font-size:48px;font-weight:700;text-align:center;margin-bottom:80px;color:#5e9ef5}.features-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px}.feature-card{background:#f8f9fa;border-radius:16px;padding:32px;transition:all .3s cubic-bezier(.4,0,.2,1);border:2px solid transparent}.feature-card:hover{transform:translateY(-8px);box-shadow:0 16px 48px #5e9ef526;border-color:#5e9ef5}.feature-icon{width:64px;height:64px;background:#5e9ef5;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;color:#fff}.feature-card h4{font-size:24px;font-weight:600;margin:0 0 12px;color:#333}.feature-card p{font-size:16px;line-height:1.6;margin:0;color:#666}.cta-section{padding:120px 20px;background:#f5f5f5;color:#333;position:relative;z-index:1}.cta-content{max-width:800px;margin:0 auto;text-align:center}.cta-content h3{font-size:48px;font-weight:700;margin:0 0 16px;color:#1a1a1a}.cta-content p{font-size:20px;margin:0 0 48px;color:#555}.footer{padding:48px 20px;background:#fff;text-align:center;color:#666;position:relative;z-index:1;border-top:1px solid #e0e0e0}.footer p{margin:8px 0;font-size:14px}.footer-note{font-size:12px;opacity:.7}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.hero{padding:60px 24px}.hero-title{font-size:52px}.brand-name{font-size:40px}.hero-description{font-size:18px}.features{padding:100px 24px}.section-title{font-size:42px}.features-grid{gap:28px}.cta-section{padding:100px 24px}.cta-content h3{font-size:42px}}@media(max-width:768px){.landing-page:before{background-size:15px 15px}.hero{min-height:100vh;min-height:100dvh;padding:40px 20px;display:flex;align-items:center;justify-content:center}.hero-content{width:100%;max-width:100%;padding:0 10px}.logo-container{gap:12px;margin-bottom:24px}.logo-animated{width:70px;height:70px;border-radius:18px}.logo-animated svg{width:45px;height:45px}.brand-name{font-size:36px}.hero-title{font-size:38px;margin:20px 0;line-height:1.3}.hero-description{font-size:17px;line-height:1.6;margin:24px 0;padding:0 10px}.cta-buttons{margin:36px 0}.btn-primary{padding:16px 32px;font-size:17px;gap:10px;width:auto;max-width:100%}.btn-primary svg{width:18px;height:18px}.hero-info{gap:20px;margin-top:32px}.info-item{font-size:14px}.features{padding:80px 20px}.section-title{font-size:36px;margin-bottom:48px}.features-grid{grid-template-columns:1fr;gap:24px}.feature-card{padding:24px}.feature-card:hover{transform:translateY(-4px)}.cta-section{padding:80px 20px}.cta-content h3{font-size:36px}.cta-content p{font-size:17px;margin-bottom:32px}.shape{opacity:.3}.shape-1{width:280px;height:280px;top:5%;left:-120px}.shape-2{width:220px;height:220px;bottom:5%;right:-80px}.shape-3,.shape-4{display:none}}@media(max-width:480px){.hero{padding:30px 16px;min-height:100dvh}.hero-content{padding:0 5px}.logo-animated{width:60px;height:60px;border-radius:16px}.logo-animated svg{width:38px;height:38px}.brand-name{font-size:28px}.hero-title{font-size:30px;margin:16px 0}.hero-description{font-size:16px;margin:20px 0;padding:0 5px}.cta-buttons{margin:30px 0}.btn-primary{padding:15px 30px;font-size:16px;width:100%;max-width:320px;justify-content:center}.hero-info{gap:16px;margin-top:30px;flex-direction:column;align-items:center}.info-item{font-size:14px}.features{padding:60px 16px}.section-title{font-size:32px;margin-bottom:40px}.features-grid{gap:20px}.feature-card{padding:20px}.feature-icon{width:56px;height:56px}.feature-card h4{font-size:20px}.feature-card p{font-size:15px}.cta-section{padding:60px 16px}.cta-content h3{font-size:32px;line-height:1.3}.cta-content p{font-size:16px;margin-bottom:28px}.footer{padding:32px 16px}.footer p{font-size:13px}.shape-1{width:200px;height:200px;left:-100px}.shape-2{width:180px;height:180px;right:-60px}}@media(max-width:375px){.hero{padding:20px 12px;min-height:100dvh}.hero-content{padding:0}.logo-animated{width:55px;height:55px}.logo-animated svg{width:35px;height:35px}.brand-name{font-size:26px}.hero-title{font-size:26px;line-height:1.3}.hero-description{font-size:15px;padding:0}.btn-primary{padding:14px 26px;font-size:15px;max-width:280px}.features{padding:50px 12px}.section-title{font-size:28px;margin-bottom:32px}.features-grid{gap:16px}.feature-card{padding:18px}.cta-section{padding:50px 12px}.cta-content h3{font-size:28px}.cta-content p{font-size:15px}}.dark-mode .landing-page{background:linear-gradient(135deg,#1a1a2e,#16213e)}.dark-mode .features{background:#0f0f1e;color:#fff}.dark-mode .feature-card{background:#1a1a2e;border-color:#2a2a3e}.dark-mode .feature-card:hover{border-color:#5e9ef5}.dark-mode .feature-card h4{color:#fff}.dark-mode .feature-card p{color:#aaa}@media(hover:none)and (pointer:coarse){.btn-primary:hover,.feature-card:hover{transform:none}.btn-primary:active{transform:scale(.98);transition:transform .1s}.feature-card:active{transform:scale(.99);transition:transform .1s}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.shape,.logo-animated{animation:none!important}}
