body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.side-panel{background-color:#1e1e1e;border-right:1px solid #333;bottom:0;box-sizing:border-box;color:#ccc;display:flex;flex-direction:column;height:100vh;left:0;max-width:25vw;min-height:0;overflow:hidden;position:fixed;top:0;touch-action:manipulation;transition:transform .3s ease;width:25vw;z-index:2000}.side-panel.open{transform:translateX(0)}.side-panel.closed{transform:translateX(-100%)}.side-panel.disabled{opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}.search-container{background-color:#1e1e1e;flex-shrink:0;padding:15px 20px}.search-input-wrap{align-items:center;display:flex;position:relative}.search-input{background-color:#2a2a2a;border:1px solid #444;border-radius:4px;color:#e0e0e0;font-family:inherit;font-size:14px;outline:none;padding:8px 12px;transition:border-color .2s;width:100%}.search-input:focus{border-color:#f44}.search-input::placeholder{color:#888}.search-clear{background:none;border:none;border-radius:50%;color:#888;cursor:pointer;font-size:16px;padding:4px;position:absolute;right:8px;transition:color .2s}.search-clear:hover{color:#f44}.panel-content{box-sizing:border-box;display:flex;flex-direction:column;height:100%;max-width:100%;min-height:0;opacity:1;overflow:hidden;padding:0;transition:opacity .3s ease;width:100%}.side-panel.closed .panel-content{opacity:0;pointer-events:none}.panel-content h2{border-bottom:none;color:#fff;margin-bottom:15px;margin-top:0;padding-bottom:0}.note-editor{display:flex;flex-direction:column;padding:0}.note-editor,.note-editor-padding{box-sizing:border-box;margin:0;max-width:100%;min-width:0;overflow:hidden;width:100%}.note-editor-padding{padding-left:32px;padding-right:32px}.note-textarea{background-color:#2a2a2a;border:1px solid #333;border-radius:4px;box-sizing:border-box;color:#e0e0e0;display:block;flex:1 1;font-family:inherit;font-size:16px;margin:18px 0 0;max-height:none;max-width:100%;min-height:120px;outline:none;overflow-y:auto;padding:10px;resize:none;scrollbar-color:#4f4f4f #0000;scrollbar-width:thin;-webkit-user-select:text;user-select:text;width:100%}.note-textarea:focus{box-shadow:none}.note-textarea:active,.note-textarea:focus{border-color:#333;outline:none}.note-textarea::-webkit-scrollbar{width:8px}.note-textarea::-webkit-scrollbar-track{background:#0000}.note-textarea::-webkit-scrollbar-thumb{background-color:#4f4f4f;border:1px solid #2a2a2a;border-radius:4px}.note-textarea::-webkit-scrollbar-thumb:hover{background-color:#6a6a6a}.note-textarea::-webkit-scrollbar-corner{background:#0000}.note-placeholder{color:#888;margin-bottom:15px}.note-list-container::-webkit-scrollbar{width:10px}.note-list-container::-webkit-scrollbar-track{background:#0000}.note-list-container::-webkit-scrollbar-thumb{background-color:#4f4f4f;border:2px solid #1e1e1e;border-radius:5px}.note-list-container::-webkit-scrollbar-thumb:hover{background-color:#6a6a6a}.note-controls{align-items:center;box-sizing:border-box;display:flex;flex-shrink:0;gap:10px;margin-bottom:15px;min-height:44px;width:100%}.note-controls label{color:#aaa;font-size:14px}.group-name-input{background-color:#2a2a2a;border:1px solid #333;border-radius:4px;color:#e0e0e0;flex-grow:1;font-family:inherit;font-size:14px;max-width:300px;min-width:0;padding:5px 8px;width:100%}.marker-color-picker{background-color:initial;border:1px solid #555;border-radius:4px;cursor:pointer;height:40px;max-width:40px;min-width:40px;padding:2px;width:40px}.file-upload-wrapper{display:inline-block;margin-left:0;margin-top:16px;position:relative}.file-upload-label{background:#232323;border:1px solid #444;border-radius:4px;color:#e0e0e0;cursor:pointer;display:inline-block;font-size:14px;padding:6px 16px;transition:background .2s,border .2s}.file-upload-label:hover{background:#333;border-color:#f44;color:#fff}.file-upload-input{display:none}.file-upload-filename{color:#aaa;font-size:13px;margin-left:10px;vertical-align:middle}.tab-bar{border-bottom:1px solid #444;display:flex;margin-bottom:0;margin-top:8px}.tab-btn{background:none;border:none;color:#aaa;cursor:pointer;flex:1 1;font-size:15px;font-weight:700;outline:none;padding:6px 0;transition:color .2s}.tab-btn.active{color:#f44}.note-list-tab{align-items:center;background:#0000;border-right:1px solid #333;cursor:pointer;display:flex;height:100%;justify-content:center;transition:background .2s;width:48px;z-index:10}.note-list-tab:hover span span{background:#bbb}.note-list-vertical{background:none;border-right:none;box-shadow:none;display:flex;flex-direction:column;height:100%;min-height:0;position:relative;transition:none;width:100%;z-index:20}.note-list-vertical-header{align-items:center;background:none;border-bottom:none;display:flex;height:38px;justify-content:flex-end;padding:0 8px}.note-list-close-btn{background:none;border:none;border-radius:4px;color:#aaa;cursor:pointer;font-size:22px;padding:0 4px;transition:background .2s,color .2s}.note-list-close-btn:hover{background:#333;color:#fff}.note-list-vertical .note-list-container{background:#1e1e1e;border-top:1px solid #333;box-shadow:none;flex:1 1;margin-top:25px;min-height:0;padding-top:15px}.custom-color-picker{appearance:none;-webkit-appearance:none;background:#0000;border:1px solid #333;border-radius:5px;box-shadow:none;box-sizing:border-box;cursor:pointer;display:inline-block;height:32px;margin:0;outline:none;padding:0;transition:background .2s,border-color .2s;vertical-align:middle;width:32px}.custom-color-picker::-webkit-color-swatch{border:none;border-radius:4px;margin:0;padding:0}.custom-color-picker::-webkit-color-swatch-wrapper{border-radius:4px;margin:0;padding:0}.custom-color-picker:focus,.custom-color-picker:hover{background:#232323;border-color:#555}@media (max-width:900px){.side-panel{border-radius:0;left:0;max-width:100vw;min-width:0;right:0;width:100vw;z-index:3000}.panel-content{padding:10px}.file-upload-label,.group-name-input,.note-textarea,.tab-btn{font-size:18px;min-height:44px}.marker-color-picker{height:40px;width:40px}.note-list-tab{font-size:28px;min-width:44px;width:44px}.note-group li{font-size:18px;min-height:48px;padding:12px 16px}.note-list-container{padding-right:0}}@media (max-width:1400px) and (min-width:901px){.side-panel{max-width:50vw;min-width:0;width:50vw}.panel-content{padding:14px}.file-upload-label,.group-name-input,.note-textarea,.tab-btn{font-size:16px;min-height:38px}.marker-color-picker{height:34px;width:34px}.note-list-tab{font-size:22px;min-width:36px;width:36px}.note-group li{font-size:16px;min-height:40px;padding:10px 12px}.note-list-container{padding-right:0}}@media (max-width:1400px){.note-textarea{min-height:100px}}.files-scroll-container{box-sizing:border-box;margin:0;max-width:100%;min-width:0;overflow-x:auto;overflow-y:hidden;padding:0;width:100%}.files-scroll-container::-webkit-scrollbar{height:6px}.files-scroll-container::-webkit-scrollbar-track{background:#1a1a1a;border-radius:3px}.files-scroll-container::-webkit-scrollbar-thumb{background-color:#555;border-radius:3px}.files-scroll-container::-webkit-scrollbar-thumb:hover{background-color:#777}.files-scroll-container{scrollbar-color:#555 #1a1a1a;scrollbar-width:thin}.images-container::-webkit-scrollbar{width:6px}.images-container::-webkit-scrollbar-track{background:#0000;border-radius:3px}.images-container::-webkit-scrollbar-thumb{background-color:initial;border-radius:3px;-webkit-transition:background-color .3s ease;transition:background-color .3s ease}.images-container::-webkit-scrollbar-thumb:hover{background-color:#777}.images-container:active::-webkit-scrollbar-thumb,.images-container:focus::-webkit-scrollbar-thumb{background-color:#555}.images-container{scrollbar-color:#0000 #0000;scrollbar-width:thin}.images-container:active,.images-container:focus{scrollbar-color:#555 #0000}@keyframes fadeInOut{0%{opacity:0;transform:scale(.8)}20%{opacity:1;transform:scale(1.1)}80%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}.note-list-container{border-top:1px solid #333;flex-grow:1;margin-top:25px;min-height:0;overflow-y:auto;padding-left:40px;padding-right:10px;padding-top:0}.group-title-clickable,.note-group h3{font-size:16px;margin-bottom:10px;margin-left:0;padding-left:0}.group-title-clickable{cursor:pointer;transition:background-color .2s}.group-title-clickable:hover{background-color:#ffffff0d;border-radius:4px}.editable-group-title{align-items:center;display:flex;gap:8px;margin-bottom:10px;margin-left:0;padding:0}.group-title-input{background:#1a1a1a;border:1px solid;border-radius:4px;color:inherit;flex:1 1;font-family:inherit;font-size:16px;margin:0;outline:none;padding:6px 8px}.group-color-picker{background:none;border:1px solid #555;border-radius:3px;cursor:pointer;height:24px;margin:0;padding:0;width:24px}.group-color-picker::-webkit-color-swatch-wrapper{padding:0}.group-color-picker::-webkit-color-swatch{border:none;border-radius:2px}.group-color-picker::-moz-color-swatch{border:none;border-radius:2px}.group-title-input:focus{background:#232323;border-width:2px}.edit-controls{display:flex;gap:4px;margin:0}.edit-btn{align-items:center;background:#333;border:1px solid #555;border-radius:3px;color:#ccc;cursor:pointer;display:flex;font-size:12px;height:24px;justify-content:center;min-width:24px;padding:4px 8px;transition:background-color .2s,color .2s}.edit-btn:hover{background:#444;color:#fff}.save-btn:hover{background:#2a5a2a;border-color:#4a7a4a}.note-group ul{margin-bottom:20px;padding-left:0}.note-group li,.note-group ul{list-style:none;overflow:visible}.note-group li{word-wrap:break-word;background:#1a1a1a;border:1px solid #333;border-radius:6px;color:#ccc;cursor:pointer;font-size:13px;margin-bottom:6px;min-height:46px;padding:8px 12px;transition:background .2s,border .2s;word-break:break-word}.note-group li.selected-note{background:#232323;border-color:#fff;color:#fff;font-weight:700}.note-group li:hover{background:#232323;border-color:#555;color:#fff}.note-date{margin-top:2px}.hierarchy-container{margin-bottom:0;overflow:visible;transition:all .3s ease-in-out}.hierarchy-container.collapsed{margin-bottom:0;max-height:0;opacity:0;overflow:hidden}.hierarchy-container.expanded{max-height:none;opacity:1;overflow:visible}.collapse-button{transition:transform .3s ease-in-out}.collapse-button:hover{color:#fff!important}.note-group{overflow:visible;transition:margin-bottom .3s ease-in-out}.level-separator{background-color:#1a1a1a;border-bottom:1px solid #444;border-top:1px solid #444;margin:15px 0 10px;padding:8px 0;text-align:center}.level-separator span{color:#888;font-family:monospace;font-size:12px;font-weight:700}.hierarchy-point{margin-bottom:0}.point-header{background:none;border-left:none;border-radius:0;color:#888;font-size:12px;font-weight:400;margin-bottom:2px;padding:2px 8px}.children-list{border-left:1px solid #333;list-style:none;margin:0 0 0 15px;overflow:visible;padding:0 0 0 15px}.children-list li{word-wrap:break-word;background:none;border:none;border-radius:0;color:#aaa;cursor:pointer;font-size:12px;list-style:none;margin:0 0 20px;overflow:visible;padding:0 0 0 5px;word-break:break-word}.children-list li:hover{background-color:#232323;color:#fff}.project-controls{display:flex;flex-direction:column;gap:10px;margin-bottom:15px;padding:15px 20px}.project-controls-row{display:flex;flex-wrap:wrap;gap:10px}.project-btn{align-items:center;background:#2a2a2a;border:1px solid #444;border-radius:4px;box-sizing:border-box;color:#e0e0e0;cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:14px;font-weight:600;gap:8px;height:40px;justify-content:center;min-width:120px;padding:8px 16px;transition:background .2s,border .2s}.project-btn.info-btn{box-sizing:border-box;flex:0 0 auto;height:40px;min-width:40px;padding:8px;width:40px}.info-icon{height:16px;width:16px}.project-btn:hover{background:#333;border-color:#f44}.project-btn:active{background:#c22}@media (max-width:900px){.project-btn{font-size:16px;padding:12px 16px}.project-btn,.project-btn.info-btn{height:44px;min-height:44px}}@media (max-width:1400px) and (min-width:901px){.project-btn{font-size:15px;padding:10px 14px}.project-btn,.project-btn.info-btn{height:38px;min-height:38px}}.branch-subtree{border-radius:0;margin:0;padding:0}.branch-subtree,.branch-subtree .branch-subtree{background:none;border-left:none;overflow:visible}.link-preview-card{background-color:#141414e6;border:1px solid #fff;border-radius:3px;box-shadow:0 4px 12px #0000004d;box-sizing:border-box;color:#e0e0e0;display:flex;flex-direction:column;font-size:11px;font-size:calc(var(--tooltip-font-size, 12px) - 1px);height:135px;margin-top:10px;overflow:hidden;position:relative;text-decoration:none;touch-action:manipulation;transition:background-color .2s;width:300px;z-index:2000}.link-preview-link{color:inherit;display:flex;flex:1 1;flex-direction:column;min-height:0;text-decoration:none}.link-preview-card:hover{background-color:#282828f2}.link-preview-card .link-edit-btn{align-items:center;background:#0006;border:none;border-radius:6px;bottom:8px;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;opacity:0;padding:0;position:absolute;right:8px;transition:opacity .2s,background .2s;width:40px;z-index:10}.link-preview-card .link-edit-btn:hover{background:#4caf50e6;color:#fff}.link-preview-card:hover .link-edit-btn{opacity:.7}.link-preview-card .link-edit-btn:hover{opacity:1}@media (hover:none){.link-preview-card .link-edit-btn{opacity:.85}}.link-preview-card.loading{color:#888;font-style:italic;padding:10px;text-align:center}.link-preview-card.link-preview-fallback{align-items:flex-start;display:flex;min-height:60px;padding:10px 36px 10px 10px}.link-preview-card .link-preview-fallback-url{color:#8ab4f8;font-size:1em;line-height:1.35;text-decoration:underline;word-break:break-all}.link-preview-card .link-preview-fallback-url:hover{color:#a8c7fa}.preview-image{background-color:#1e1e1e;border-bottom:1px solid #444;height:80px;object-fit:cover;width:100%}.preview-content{display:flex;flex-direction:column;flex-grow:1;padding:7px 10px}.preview-title{color:#e0e0e0;font-size:1em;font-weight:700;margin-bottom:3px;white-space:nowrap}.preview-description,.preview-title{box-sizing:border-box;overflow:hidden;padding-left:7px;padding-right:7px;text-overflow:ellipsis;word-break:break-word}.preview-description{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;flex-grow:0;font-size:.95em;height:1.3em;line-height:1.3;margin-bottom:5px}.preview-site{align-items:center;color:#aaa;display:flex;font-size:.9em;gap:5px}.preview-favicon{border-radius:1px;height:10px;width:10px}.link-preview-card[data-marker-color]{border-color:attr(data-marker-color color)}.link-preview-card-with-note{border-radius:8px;border-width:2px;max-height:160px;min-height:120px;overflow:hidden;width:280px}.link-preview-card-with-note .link-preview-link{display:flex;flex-direction:column;min-height:0}.link-preview-card-with-note .preview-image{background-color:#1a1a1a;flex-shrink:0;height:72px;object-fit:cover;width:100%}.link-preview-card-with-note .preview-content{background-color:#252525;display:flex;flex:1 1;flex-direction:column;gap:6px;justify-content:center;min-height:0;padding:12px 14px 14px}.link-preview-card-with-note .preview-title{color:#fff;font-size:1em;font-weight:600;margin-bottom:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.link-preview-card-with-note .preview-description{-webkit-line-clamp:2;color:#b0b0b0;font-size:.95em;font-weight:700;height:auto;line-height:1.4;margin-bottom:0;min-height:1.4em;padding:0}.link-preview-card-with-note .preview-site{color:#888;font-size:.9em;margin-top:2px}.link-preview-card-with-note .preview-favicon{height:12px;width:12px}.toggle-button{background-color:#2a2a2a;border:1px solid #333;border-left:none;border-radius:0 8px 8px 0;color:#ccc;cursor:pointer;font-size:18px;height:60px;line-height:60px;padding:0;position:absolute;text-align:center;top:50%;transform:translateY(-50%);transition:left .3s ease;width:20px;z-index:101}.toggle-button.open{left:25vw}.toggle-button.closed{left:0}@media (max-width:900px){.toggle-button{border-radius:0 12px 12px 0;font-size:28px;height:44px;left:auto!important;line-height:44px;right:0;top:50%;transform:translateY(-50%);width:44px;z-index:4000}}@media (max-width:1400px) and (min-width:901px){.toggle-button.open{left:50vw;right:auto}.toggle-button.closed{left:0;right:auto}.toggle-button{border-radius:0 8px 8px 0;font-size:18px;height:60px;line-height:60px;position:absolute;top:50%;transform:translateY(-50%);width:20px;z-index:4000}}.toggle-create-mode-wrapper{position:fixed;right:16px;top:144px;width:40px;z-index:1000}.toggle-create-mode{background:#282828cc;border:1px solid #fff3;border-radius:6px;cursor:pointer;height:40px;padding:0;transition:background-color .2s;width:40px}.toggle-create-mode,.toggle-create-mode-content{align-items:center;display:flex;justify-content:center}.toggle-create-mode-content{flex-direction:column;gap:2px}.toggle-remaining{color:#ffffffe6;font-size:10px;font-weight:600;line-height:1}.toggle-create-mode:hover{background:#3c3c3ce6}.toggle-create-mode.disabled{background:#281414cc;border-color:#8b000080}.toggle-create-mode.disabled:hover{background:#3c1e1ee6}.toggle-create-mode-content .toggle-indicator{background:#4caf50;border-radius:50%;height:12px;transition:all .2s ease;width:12px}.toggle-create-mode.disabled .toggle-indicator{background:#ff6b6b}.toggle-create-mode.limit-reached{cursor:not-allowed;opacity:.5}.delete-marker-btn{align-items:center;background:#282828cc;border:1px solid #fff3;border-radius:6px;bottom:80px;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;position:fixed;right:20px;touch-action:manipulation;transition:background-color .2s,border-color .2s;width:40px;z-index:1000}.delete-marker-btn:hover:not(:disabled){background:#3c3c3ce6}.delete-marker-btn:not(:disabled){color:#ff6b6b}.delete-marker-btn.disabled,.delete-marker-btn:disabled{background:#14141480;color:#ffffff4d;cursor:not-allowed;opacity:.5}.note-tooltip{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;align-items:flex-start;backface-visibility:hidden;-webkit-backface-visibility:hidden;background-color:#141414e6;border:1px solid;border-color:inherit;border-radius:3px;box-shadow:0 4px 12px #0000004d;box-sizing:border-box;color:#e0e0e0;cursor:pointer;display:flex;font-size:12px;font-size:var(--tooltip-font-size,12px);height:135px;justify-content:flex-start;margin-top:10px;max-height:calc(100vh - 200px);max-width:50vw;overflow-y:auto;pointer-events:auto;text-align:left;text-rendering:optimizeLegibility;touch-action:manipulation;transition:opacity .1s ease-in-out;white-space:pre-wrap;width:300px;word-break:break-word;z-index:2000}.note-tooltip:hover{background-color:#1e1e1ef2;box-shadow:0 6px 16px #0006}.note-tooltip.editing{border:2px solid #4caf50}.note-tooltip.editing,.note-tooltip.expanded{background-color:#141414f2;box-shadow:0 8px 24px #00000080;cursor:default;pointer-events:auto}.note-tooltip.expanded{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;backface-visibility:hidden;-webkit-backface-visibility:hidden;border:2px solid #6cf;border-radius:6px;font-size:12px;font-size:var(--tooltip-font-size,12px);text-rendering:optimizeLegibility}.note-tooltip[data-marker-color]{border-color:attr(data-marker-color color)}.note-tooltip-empty{align-items:center!important;border-radius:4px!important;box-shadow:0 2px 8px #0006!important;display:flex!important;height:40px!important;justify-content:center!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.note-tooltip-empty:hover{background-color:#1e1e1ef2!important;box-shadow:0 4px 12px #00000080!important;transform:scale(1.1)}.note-tooltip-empty-buttons{align-items:center!important;background-color:initial!important;border:none!important;border-radius:4px!important;display:flex!important;gap:10px!important;height:40px!important;justify-content:center!important;min-height:40px!important;min-width:90px!important;padding:0!important;width:90px!important}.note-tooltip-empty-buttons[data-zero-level-point=true]{gap:0!important;min-width:40px!important;width:40px!important}.note-tooltip-empty-button{align-items:center!important;background-color:#141414e6!important;border-radius:4px!important;border-style:solid!important;border-width:1px!important;box-shadow:0 4px 12px #0009,0 2px 4px #0006!important;cursor:pointer!important;display:flex!important;height:40px!important;justify-content:center!important;transition:background-color .2s ease,box-shadow .2s ease!important;width:40px!important}.note-tooltip-empty-button:hover{background-color:#1e1e1ef2!important;box-shadow:0 6px 16px #000000b3,0 2px 4px #00000080!important}.image-upload-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;cursor:pointer;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;touch-action:manipulation;z-index:10000}.image-upload-modal{background-color:#1e1e1ef2;border:none;border-radius:8px;box-shadow:0 8px 32px #00000080;cursor:default;max-height:90vh;max-width:90vw;min-height:300px;padding:30px;position:relative;width:500px}.note-date{color:#aaa;font-size:10px;margin-top:4px}.note-date-corner{bottom:4px;color:#aaa;font-size:7px;margin:0;pointer-events:none;position:absolute;right:8px}.note-tooltip-textarea::-webkit-scrollbar{width:10px}.note-tooltip-textarea::-webkit-scrollbar-track{background:#0000}.note-tooltip-textarea::-webkit-scrollbar-thumb{background-color:#4f4f4f;border:2px solid #1e1e1e;border-radius:5px}.note-tooltip-textarea::-webkit-scrollbar-thumb:hover{background-color:#6a6a6a}.note-tooltip.expanded::-webkit-scrollbar{width:8px}.note-tooltip.expanded::-webkit-scrollbar-track{background:#0000}.note-tooltip.expanded::-webkit-scrollbar-thumb{background-color:#4f4f4f;border:1px solid #1e1e1e;border-radius:4px}.note-tooltip.expanded::-webkit-scrollbar-thumb:hover{background-color:#6a6a6a}.image-tooltip{align-items:center;background:#181818;border-radius:8px;border-width:2px;box-shadow:0 6px 24px #000b;display:flex;height:180px;justify-content:center;max-width:300px;overflow:hidden;padding:0;position:fixed;width:240px}.image-tooltip img{border-radius:8px;display:block;height:100%;object-fit:cover;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%}.slider-arrow{align-items:center;background:#00000073;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:22px;height:48px;justify-content:center;opacity:.85;outline:none;position:absolute;top:50%;transform:translateY(-50%);transition:background .2s,opacity .2s;width:32px;z-index:2}.slider-arrow.left{left:4px}.slider-arrow.right{right:4px}.slider-arrow:hover{background:#000000b3;opacity:1}.slider-dots{bottom:10px;display:flex;gap:7px;justify-content:center;left:0;position:absolute;right:0;z-index:2}.slider-dots span{background:#bbb;border-radius:50%;display:inline-block;height:8px;opacity:.6;transition:background .2s,opacity .2s;width:8px}.slider-dots span.active{background:#fff;opacity:1}.resize-handle{background:linear-gradient(-45deg,#0000 30%,#666 0,#666 40%,#0000 0,#0000 60%,#666 0,#666 70%,#0000 0);bottom:0;cursor:nw-resize;height:20px;opacity:.6;position:absolute;right:0;transition:opacity .2s;width:20px;z-index:2500}.resize-handle:hover{background:linear-gradient(-45deg,#0000 30%,#888 0,#888 40%,#0000 0,#0000 60%,#888 0,#888 70%,#0000 0);opacity:1}.note-tooltip.expanded.resizing{cursor:nw-resize;-webkit-user-select:none;user-select:none}.note-tooltip.expanded.resizing *{pointer-events:none}.note-tooltip.expanded.resizing .resize-handle{pointer-events:auto}.note-tooltip.expanded.dragging{box-shadow:0 12px 32px #0009;cursor:grabbing;transition:none;-webkit-user-select:none;user-select:none}.note-tooltip.expanded.dragging *{pointer-events:none}.note-tooltip.expanded.dragging .resize-handle{pointer-events:auto}.note-tooltip.expanded{transition:box-shadow .2s ease-in-out}.note-tooltip.expanded:hover{box-shadow:0 10px 28px #0000008c}.note-tooltip.expanded[style*="user-select: none"]{-webkit-user-select:none;user-select:none}.tooltip-close-btn{opacity:.7;transition:color .2s ease-in-out}.tooltip-close-btn:hover{color:#fff!important;opacity:1}.tooltip-close-btn:active{color:#ccc!important;opacity:.8}.tooltip-edit-btn{opacity:.7;transition:color .2s ease-in-out}.tooltip-edit-btn:hover{color:#fff!important;opacity:1}.tooltip-edit-btn:active{color:#ccc!important;opacity:.8}.note-tooltip::-webkit-scrollbar{width:8px}.note-tooltip::-webkit-scrollbar-track{background:#1e1e1e;border-radius:4px}.note-tooltip::-webkit-scrollbar-thumb{background:#4f4f4f;border-radius:4px}.note-tooltip::-webkit-scrollbar-thumb:hover{background:#6f6f6f}.note-tooltip.image-tooltip .image-enlarge-btn{align-items:center;background:#0006;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;opacity:0;padding:0;position:absolute;right:8px;top:8px;transition:opacity .2s,background .2s;width:40px;z-index:10}.note-tooltip.image-tooltip .image-enlarge-btn:hover{background:#4caf50e6;color:#fff}.note-tooltip.image-tooltip:hover .image-enlarge-btn{opacity:.7}.note-tooltip.image-tooltip .image-enlarge-btn:hover{opacity:1}.note-tooltip.image-tooltip.image-tooltip-zoomed .image-enlarge-btn{display:none}.note-tooltip.image-tooltip .image-delete-btn{align-items:center;background:#0006;border:none;border-radius:6px;bottom:8px;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;opacity:0;padding:0;position:absolute;right:8px;transition:opacity .2s,background .2s;width:40px;z-index:10}.note-tooltip.image-tooltip .image-delete-btn:hover{background:#dc3545e6;color:#fff;opacity:1}@media (hover:none){.note-tooltip.image-tooltip .image-delete-btn,.note-tooltip.image-tooltip .image-enlarge-btn{opacity:.85}}.note-tooltip.image-tooltip.image-tooltip-zoomed .image-delete-btn{display:none}.camera-controls{align-items:stretch;display:flex;flex-direction:column;gap:8px;position:absolute;right:16px;top:64px;width:40px;z-index:1000}.camera-top-btn{align-items:center;border-radius:6px;cursor:pointer;display:flex;font-size:12px;font-weight:600;height:40px;justify-content:center;padding:0;transition:background-color .2s;width:40px}.camera-top-btn:disabled{cursor:not-allowed}.camera-top-btn.toggle-3d-btn{height:24px}.camera-rotate-controls{align-items:center;bottom:20px;display:flex;gap:12px;left:50%;position:absolute;transform:translateX(-50%);z-index:1000}.reset-camera-btn{align-items:center;background:#0000;border:none;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;transition:transform .2s;width:40px}.reset-camera-btn:hover{transform:scale(1.15)}.reset-camera-btn .camera-control-icon{filter:brightness(0) saturate(100%) invert(100%);height:40px;opacity:.2;transition:opacity .2s ease;width:40px}.reset-camera-btn:hover .camera-control-icon{opacity:1}.rotate-btn{align-items:center;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;transition:background-color .2s;width:40px}.rotate-btn,.rotate-btn:hover{background-color:initial}.rotate-btn:hover .camera-control-icon{opacity:1}.rotate-btn .camera-control-icon{filter:brightness(0) saturate(100%) invert(100%);height:30px;opacity:.2;transition:transform .3s ease,opacity .2s ease;width:30px}.rotate-btn.rotate-left:hover .camera-control-icon{transform:rotate(45deg)}.rotate-btn.rotate-right:hover .camera-control-icon{transform:rotate(-45deg)}@keyframes pulse{0%,to{box-shadow:0 0 20px #ffd700cc,0 0 40px #ffd70066}50%{box-shadow:0 0 30px gold,0 0 60px #ffd70099}}.create-file-storage-btn.highlight,.reset-camera-btn.highlight,.rotate-btn.highlight{animation:pulse 1.5s ease-in-out infinite}.create-file-storage-btn{align-items:center;background:#282828cc;border:1px solid #fff3;border-radius:6px;bottom:140px;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;overflow:visible;padding:0;pointer-events:auto;position:fixed;right:20px;transition:background-color .2s,border-color .2s;width:40px;z-index:3000}.create-file-storage-icon-wrap{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.create-file-storage-btn:hover:not(:disabled){background:#3c3c3ce6}.create-file-storage-btn.active{background:#bbbbbb40;border-color:#fff6}.create-file-storage-btn.disabled{background:#14141480;color:#ffffff4d;cursor:not-allowed;opacity:.5}.create-file-storage-btn.highlight{border-color:#ffd700cc;box-shadow:0 0 20px #ffd700cc,0 0 40px #ffd70066}.create-file-storage-icon{color:currentColor;display:block;flex-shrink:0;height:26px;transform:translateY(-3px);width:26px}.create-file-storage-remaining{background:#000000d9;border:1.5px solid #ffffffe6;border-radius:50%;bottom:-3px;box-sizing:border-box;font-size:10px;font-weight:700;height:16px;line-height:14px;min-width:16px;padding:0 4px;position:absolute;right:-3px}.create-file-storage-remaining,.right-click-mode-btn{align-items:center;color:#fff;display:flex;justify-content:center}.right-click-mode-btn{background:#282828cc;border:1px solid #fff3;border-radius:50%;bottom:28px;cursor:pointer;height:88px;left:28px;padding:0;position:fixed;transition:background-color .2s,border-color .2s,transform .2s;width:88px;z-index:3000}.right-click-mode-btn:hover{background:#3c3c3ce6;border-color:#ffffff4d}.right-click-mode-btn.active{background:#5078b499;border-color:#6496dccc;transform:scale(1.05)}.right-click-mode-btn.active:hover{background:#5a82beb3}.right-click-mode-icon{filter:brightness(0) saturate(100%) invert(100%);height:48px;pointer-events:none;width:48px}.project-actions-trigger{align-items:center;background:#282828cc;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;position:fixed;transition:background-color .2s,border-color .2s;width:40px;z-index:3000}.project-actions-trigger:hover{background:#3c3c3ce6}.project-actions-trigger{bottom:20px;right:20px}.project-actions-modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;touch-action:manipulation;z-index:10000}.project-actions-modal{background:#1a1a1a;border:1px solid #444;border-radius:8px;box-shadow:0 8px 32px #00000080;min-width:260px}.project-actions-modal-header{align-items:center;border-bottom:1px solid #333;color:#e0e0e0;display:flex;font-size:14px;font-weight:600;justify-content:space-between;padding:12px 16px}.project-actions-close{background:none;border:none;color:#888;cursor:pointer;font-size:20px;line-height:1;padding:0 4px}.project-actions-close:hover{color:#fff}.project-actions-modal-body{display:flex;flex-direction:column;gap:8px;padding:12px 16px}.project-actions-modal-footer{border-top:1px solid #333;color:#666;font-size:11px;padding:8px 16px 12px;text-align:center}.project-actions-row{align-items:stretch;display:flex;gap:8px}.project-actions-font-size-row{align-items:center;display:flex}.project-actions-font-size-label{align-items:center;color:#e0e0e0;display:flex;font-size:13px;gap:10px;justify-content:space-between;width:100%}.project-actions-font-size-select{background:#2a2a2a;border:1px solid #444;border-radius:4px;color:#e0e0e0;cursor:pointer;font-size:13px;min-width:72px;padding:6px 10px}.project-actions-font-size-select:focus,.project-actions-font-size-select:hover{border-color:#6cf;outline:none}.project-action-btn-compact{flex:1 1;font-size:13px;min-width:0;padding:8px 10px}.project-action-mode-btn{align-items:center;aspect-ratio:1;display:flex;flex-shrink:0;justify-content:center;min-width:40px;padding:0;position:relative;width:40px}.project-action-btn{align-items:center;background:#2a2a2a;border:1px solid #444;border-radius:6px;color:#e0e0e0;cursor:pointer;display:flex;font-family:inherit;font-size:14px;gap:10px;padding:10px 14px;transition:background .2s,border-color .2s}.project-action-btn:hover{background:#333;border-color:#555}.project-action-btn-saved{border-color:#4ade8066;color:#4ade80}.project-action-btn-saved:hover{background:#2a2a2a}.project-action-btn.info-btn:hover{border-color:#f44}.info-icon{align-items:center;border:2px solid;border-radius:3px;display:flex;flex-shrink:0;font-family:monospace;font-size:12px;font-weight:700;height:18px;justify-content:center;width:18px}.project-file-input{display:none}.project-actions-user-section{border-top:1px solid #333;display:flex;flex-direction:column;gap:6px;margin-top:4px;padding-top:8px}.project-actions-developer-section{background:#00000040;border-radius:6px;border-top:1px solid #444;display:flex;flex-direction:column;gap:8px;margin-top:12px;padding:12px}.project-actions-developer-section .project-actions-autosave-section{border-top:1px solid #333;margin-top:4px;padding-top:8px}.project-actions-developer-label{color:#666;font-size:11px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.project-actions-user-label{color:#888;font-size:12px;margin-bottom:2px}.project-actions-user-email{color:#b0b0b0;word-break:break-all}.project-actions-user-guest{color:#666;font-style:italic}.project-action-logout-btn{color:#b0b0b0}.project-action-logout-btn:hover{border-color:#666;color:#e0e0e0}.project-action-delete-data-btn{color:#c66}.project-action-delete-data-btn:hover{border-color:#a44;color:#f88}.project-actions-autosave-section{border-top:1px solid #333;display:flex;flex-direction:column;gap:6px;margin-top:4px;padding-top:8px}.project-actions-autosave-label{color:#888;font-size:12px;margin-bottom:2px}.project-action-autosave-btn{font-size:12px;padding:8px 12px}.project-action-autosave-btn span{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-action-autosave-size{color:#888;flex-shrink:0;font-size:11px;margin-left:auto}.project-action-clear-cache-btn{color:#b0b0b0;margin-top:4px}.project-action-clear-cache-btn:hover{border-color:#666;color:#e0e0e0}.project-action-check{color:#6a6;font-size:12px;margin-left:4px}.undo-redo-buttons{bottom:140px;display:flex;flex-direction:column;gap:10px;position:fixed;right:20px;z-index:3000}.undo-redo-buttons button{align-items:center;background:#1a1a1ae6;border:2px solid #fff3;border-radius:50%;box-shadow:0 4px 12px #0000004d;color:#bbb;cursor:pointer;display:flex;height:50px;justify-content:center;transition:all .3s ease;width:50px}.undo-redo-buttons button:hover:not(.disabled){background:#282828f2;border-color:#fff6;transform:scale(1.05)}.undo-redo-buttons button.disabled{cursor:not-allowed;opacity:.3}.undo-redo-buttons button:active:not(.disabled){transform:scale(.95)}.fullscreen-viewer{background:#000000f2;height:100vh;pointer-events:auto;position:fixed;top:0;touch-action:manipulation;transition:left .3s ease,width .3s ease;z-index:10000}.fullscreen-content,.fullscreen-viewer{align-items:center;display:flex;justify-content:center}.fullscreen-content{box-sizing:border-box;cursor:grab;height:100%;padding:20px;position:relative;width:100%}.fullscreen-content:active{cursor:grabbing}.fullscreen-content-dragging{-webkit-user-select:none;user-select:none}.fullscreen-image-wrap{align-items:center;display:flex;justify-content:center;max-height:100%;max-width:100%;transition:transform .05s ease-out}.fullscreen-image{border-radius:8px;box-shadow:0 8px 32px #00000080;max-height:calc(100% - 120px);max-width:calc(100% - 40px);object-fit:contain;pointer-events:none;transition:transform .1s ease-out;-webkit-user-select:none;user-select:none}.close-button{align-items:center;background:#000c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:28px;height:50px;justify-content:center;position:absolute;right:20px;top:20px;transition:background .2s;width:50px;z-index:10001}.close-button:hover{background:#f00c}.nav-button{align-items:center;background:#000c;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:24px;height:80px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:background .2s;width:60px;z-index:10001}.nav-button:hover{background:#000000e6}.nav-button.prev{left:20px}.nav-button.next{right:20px}.image-counter{border-radius:20px;font-size:14px;font-weight:700;left:20px;padding:8px 16px;top:20px}.image-counter,.image-info{background:#000c;color:#fff;position:absolute;z-index:10001}.image-info{word-wrap:break-word;border-radius:8px;bottom:20px;left:50%;max-width:80%;padding:12px 20px;text-align:center;transform:translateX(-50%)}.image-name{font-size:16px;font-weight:700;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-size{font-size:12px;opacity:.8}@media (max-width:900px){.fullscreen-content{padding:10px}.fullscreen-image{max-height:calc(100% - 100px);max-width:calc(100% - 20px)}.close-button{font-size:24px;height:40px;right:10px;top:10px;width:40px}.nav-button{font-size:20px;height:60px;width:50px}.nav-button.prev{left:10px}.nav-button.next{right:10px}.image-counter{font-size:12px;left:10px;padding:6px 12px;top:10px}.image-info{bottom:10px;max-width:90%;padding:8px 16px}.image-name{font-size:14px}.image-size{font-size:11px}}.onboarding-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;touch-action:manipulation;z-index:10000}.onboarding-overlay.practice-overlay{background-color:initial;pointer-events:none}.onboarding-overlay.practice-overlay .onboarding-modal{pointer-events:auto}.onboarding-modal{background:#1e1e1e;border:1px solid #333;border-radius:8px;box-shadow:0 8px 32px #0000004d;max-height:70vh;max-width:480px;overflow:hidden;padding:0;width:90%}.onboarding-modal.practice-mode{margin-top:0;max-width:600px;position:absolute;top:20px}.onboarding-modal.practice-mode .onboarding-content{background:#2a2a2a;display:none;font-size:17px;line-height:1.6;padding:0}.onboarding-modal.practice-mode .onboarding-content p{font-size:17px}.onboarding-modal.practice-mode .onboarding-feature-icons,.onboarding-modal.practice-mode .onboarding-footer,.onboarding-modal.practice-mode .onboarding-progress{display:none}.onboarding-modal.final-slide .onboarding-footer{justify-content:center}.onboarding-modal.final-slide .onboarding-create-mode-info{background:#0000;border-color:#0000}.onboarding-modal.practice-mode .onboarding-btn{background:#0000;border:none;color:#999;font-weight:400;min-width:auto;padding:8px 16px;text-decoration:underline;text-underline-offset:4px}.onboarding-modal.practice-mode .onboarding-btn:hover{background:#0000;color:#fff}.onboarding-modal.practice-mode .onboarding-btn.primary{background:#0000;border:none;color:#999}.onboarding-modal.practice-mode .onboarding-btn.primary:hover{background:#0000;border:none;color:#fff}.onboarding-header{align-items:center;background:#1e1e1e;border-bottom:1px solid #333;display:flex;justify-content:space-between;padding:16px 20px}.onboarding-header .onboarding-skip{margin:0;padding:0}.onboarding-header h2{color:#e0e0e0;font-size:20px;font-weight:500;margin:0}.onboarding-close{background:none;border:none;border-radius:4px;color:#999;cursor:pointer;font-size:16px;padding:4px;transition:color .2s}.onboarding-close:hover{color:#e0e0e0}.onboarding-content{color:#ccc;line-height:1.5;max-height:350px;overflow-y:auto;padding:20px}.onboarding-content p{font-size:14px;margin:0 0 12px}.onboarding-logo{display:block;filter:brightness(0) saturate(100%) invert(80%);height:auto;margin:48px auto;opacity:.8;width:120px}.onboarding-illustration{border:1px solid #ffffff1a;border-radius:8px;display:block;height:auto;margin:16px auto;max-width:320px;width:100%}.onboarding-content .onboarding-main-text{color:#e0e0e0;font-size:22px;font-weight:500;line-height:1.4;margin-bottom:16px}.onboarding-content .onboarding-secondary-text{color:#999;font-size:14px}.onboarding-content .onboarding-hint{color:#666;font-size:12px;font-style:italic;margin-top:16px}.onboarding-create-mode-info{align-items:center;background:#2828284d;border:1px solid #ffffff1a;border-radius:6px;display:flex;gap:12px;margin-bottom:8px;margin-top:24px;padding:12px}.onboarding-create-mode-info p{color:#b0b0b0;font-size:14px;margin:0}.onboarding-create-icon{flex-shrink:0;height:32px;width:40px}.onboarding-camera-control{display:flex;flex-direction:column;gap:16px}.onboarding-camera-row{align-items:flex-start;display:flex;gap:14px}.onboarding-camera-row .onboarding-mouse-icon{filter:brightness(0) saturate(100%) invert(68%) sepia(36%) saturate(2248%) hue-rotate(174deg) brightness(101%) contrast(96%) drop-shadow(0 0 8px rgba(94,179,246,.7));flex-shrink:0;height:auto;width:50px}.onboarding-camera-row .onboarding-mouse-icon svg,.onboarding-camera-row svg.onboarding-mouse-icon{color:#5eb3f6;filter:drop-shadow(0 0 6px rgba(94,179,246,.6))}.onboarding-camera-row svg.onboarding-mouse-icon{height:50px;width:50px}.onboarding-camera-row svg.onboarding-mouse-icon circle,.onboarding-camera-row svg.onboarding-mouse-icon path,.onboarding-camera-row svg.onboarding-mouse-icon rect{stroke:#5eb3f6}.onboarding-camera-row p{margin:0 0 4px}.onboarding-camera-row p:last-child{margin-bottom:0}.onboarding-content strong{color:orange;font-weight:500}.onboarding-content ul{margin:12px 0;padding-left:16px}.onboarding-content li{font-size:14px;margin:6px 0}.dont-show-again{border-top:1px solid #333;margin-top:20px;padding-top:16px}.dont-show-again label{align-items:center;color:#ccc;cursor:pointer;display:flex;font-size:14px;gap:8px}.dont-show-again input[type=checkbox]{accent-color:orange;cursor:pointer;height:16px;width:16px}.dont-show-again span{-webkit-user-select:none;user-select:none}.onboarding-footer{align-items:center;border-top:1px solid #333;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:16px 20px}.onboarding-progress{display:flex;gap:6px}.progress-dot{background-color:#444;border-radius:50%;cursor:pointer;height:8px;transition:background-color .2s;width:8px}.progress-dot:hover{background-color:#666}.progress-dot.active{background-color:orange}.onboarding-feature-icons{align-items:center;display:flex;gap:12px}.onboarding-feature-icon-wrap{align-items:center;color:#ffffff80;display:flex;justify-content:center}.onboarding-feature-icon{flex-shrink:0;height:20px;width:20px}.onboarding-buttons{display:flex;gap:8px}.onboarding-btn{background:#2a2a2a;border:1px solid #555;border-radius:4px;color:#ccc;cursor:pointer;font-size:13px;font-weight:500;min-width:70px;padding:8px 16px;transition:all .2s}.onboarding-btn.primary{background:orange;border-color:orange;color:#1a1a1a;min-width:105px}.onboarding-btn.primary:hover{background:#ff8c00;border-color:#ff8c00}.onboarding-btn.secondary:hover{background:#333;border-color:#666}.onboarding-skip{background:none;border:none;color:#999;cursor:pointer;font-size:13px;padding:8px 0;text-decoration:underline;text-underline-offset:3px;transition:color .2s}.onboarding-skip:hover{color:#fff}.onboarding-cursor-hint{align-items:center;background:#1e1e1ef2;border:1px solid #fff3;border-radius:8px;box-shadow:0 4px 12px #0006;display:flex;gap:12px;padding:10px 14px;pointer-events:none;position:fixed;transform:translate(0);z-index:10001}.onboarding-cursor-hint-icon{filter:brightness(0) saturate(100%) invert(68%) sepia(36%) saturate(2248%) hue-rotate(174deg) brightness(101%) contrast(96%) drop-shadow(0 0 8px rgba(94,179,246,.7));flex-shrink:0;height:auto;width:64px}.peak-hint-mountain-icon{align-items:center;display:flex;filter:none;flex-shrink:0;font-size:28px;height:32px;justify-content:center;width:32px}.onboarding-cursor-hint-content{display:flex;flex-direction:column;gap:8px}.onboarding-cursor-hint-text{word-wrap:break-word;color:#e0e0e0;font-size:15px;font-weight:500;line-height:2.2;max-width:420px;white-space:pre-line}.onboarding-cursor-hint-secondary{background:#00000059;border-radius:6px;color:#b0b0b0;font-size:13px;font-weight:500;line-height:1.35;max-width:420px;padding:6px 10px}@media (max-width:600px){.onboarding-modal{margin:20px;width:95%}.onboarding-header{padding:14px 16px}.onboarding-header h2{font-size:18px}.onboarding-content{padding:16px}.onboarding-footer{align-items:stretch;flex-direction:column;padding:14px 16px}.onboarding-buttons{justify-content:center}.onboarding-cursor-hint{gap:8px;padding:8px 12px}.onboarding-cursor-hint-icon{width:24px}.onboarding-cursor-hint-text{font-size:12px}.onboarding-cursor-hint-secondary{font-size:11px;padding:5px 8px}}.loading-screen{align-items:center;display:flex;flex-direction:column;gap:12px;min-height:100vh;text-align:center}.loading-screen--compact{gap:8px}.loading-screen__content{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:12px;justify-content:center}.loading-screen--compact .loading-screen__content{gap:8px}.loading-screen__logo-wrap{display:flex;justify-content:center}.loading-screen__logo{filter:invert(1) brightness(1);height:auto;object-fit:contain;opacity:.5;width:140px}.loading-screen__icons-scroll{margin-top:0;overflow:hidden;width:140px}.loading-screen__icons-track{animation:loading-icons-scroll 6s linear infinite;display:flex;gap:12px;width:-webkit-max-content;width:max-content}.loading-screen__icon{align-items:center;color:#ffffff80;display:flex;flex-shrink:0;height:18px;justify-content:center;width:18px}.loading-screen__icon svg{height:16px;width:16px}.loading-screen__version{color:#fff6;font-size:11px;margin-top:auto;padding-bottom:20px}@keyframes loading-icons-scroll{0%{transform:translateX(0)}5%{transform:translateX(-30px)}10%{transform:translateX(-30px)}15%{transform:translateX(-60px)}20%{transform:translateX(-60px)}25%{transform:translateX(-90px)}30%{transform:translateX(-90px)}35%{transform:translateX(-120px)}40%{transform:translateX(-120px)}45%{transform:translateX(-150px)}50%{transform:translateX(-150px)}50.1%{transform:translateX(0)}55%{transform:translateX(-30px)}60%{transform:translateX(-30px)}65%{transform:translateX(-60px)}70%{transform:translateX(-60px)}75%{transform:translateX(-90px)}80%{transform:translateX(-90px)}85%{transform:translateX(-120px)}90%{transform:translateX(-120px)}95%{transform:translateX(-150px)}to{transform:translateX(-150px)}}.peak-models-manager{bottom:188px;position:fixed;right:20px;z-index:3001}.peak-models-toggle{align-items:center;background:#282828cc;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:20px;height:40px;justify-content:center;transition:background-color .2s,border-color .2s;width:40px}.peak-models-toggle:hover{background:#3c3c3ce6}.peak-models-toggle.active{background:#ffa50040;border-color:#ffa500cc}.peak-models-toggle.highlight-for-peak-hint{background:#ffa50066;border-color:orange;box-shadow:0 0 12px #ffa50099}.peak-models-panel{background:#1a1a1af2;border:1px solid #fff3;border-radius:8px;bottom:60px;box-shadow:0 8px 24px #0006;color:#fff;max-height:500px;overflow-y:auto;padding:16px;position:absolute;right:0;width:320px}.peak-models-panel h3{color:#fff;font-size:18px;margin:0 0 16px}.model-type-selector{margin-bottom:16px}.model-type-selector label{color:#ccc;display:block;font-size:14px;margin-bottom:8px}.model-type-buttons{display:flex;gap:8px}.model-type-buttons button{background:#ffffff1a;border:2px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-size:24px;padding:12px;transition:all .2s ease}.model-type-buttons button:hover{background:#ffffff26;border-color:#ffffff4d}.model-type-buttons button.active{background:#ffa5004d;border-color:orange}.peaks-list{margin-bottom:16px}.peaks-list label{color:#ccc;display:block;font-size:14px;margin-bottom:8px}.peaks-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);max-height:200px;overflow-y:auto}.peak-item{align-items:center;aspect-ratio:1;background:#ffffff0d;border:2px solid #fff3;border-radius:6px;color:#ccc;cursor:pointer;display:flex;font-size:12px;justify-content:center;position:relative;transition:all .2s ease}.peak-item:hover{background:#ffffff1a;border-color:#ffffff4d}.peak-item.selected{background:#ffa50033;border-color:orange}.peak-item.has-model{background:#4caf5033;border-color:#4caf50}.peak-number{font-weight:700}.model-icon{right:2px;top:2px}.model-icon,.remove-model-btn{font-size:14px;position:absolute}.remove-model-btn{align-items:center;background:#f44336e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:20px;justify-content:center;line-height:1;right:-6px;top:-6px;transition:all .2s ease;width:20px}.remove-model-btn:hover{background:#f44336;transform:scale(1.1)}.peak-actions{margin-bottom:16px}.place-model-btn{background:#ffa5004d;border:2px solid orange;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:12px;transition:all .2s ease;width:100%}.place-model-btn:hover:not(:disabled){background:#ffa50080}.place-model-btn:disabled{cursor:not-allowed;opacity:.5}.peak-models-info{border-top:1px solid #ffffff1a;color:#999;font-size:12px;padding-top:12px;text-align:center}.peak-model-selector-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.peak-model-selector-modal{background:#1a1a1afa;border:1px solid #fff3;border-radius:12px;box-shadow:0 8px 32px #00000080;min-width:300px;padding:24px}.peak-model-selector-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.peak-model-selector-header h3{color:#fff;font-size:20px;margin:0}.close-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;line-height:1;transition:all .2s ease;width:32px}.close-btn:hover{background:#fff3;transform:scale(1.1)}.peak-model-selector-content{display:flex;flex-direction:column;gap:12px}.model-type-option{align-items:center;background:#ffffff0d;border:2px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;gap:16px;padding:16px;position:relative;text-align:left;transition:all .2s ease}.model-type-option:hover:not(.disabled){background:#ffffff1a;border-color:#ffa50080;transform:translateX(4px)}.model-type-option.disabled{background:#ffffff05;border-color:#ffffff1a;cursor:not-allowed;opacity:.5}.model-type-option.disabled:hover{background:#ffffff05;border-color:#ffffff1a;transform:none}.model-used-indicator{color:#f44;font-size:20px;font-weight:700;line-height:1;position:absolute;right:16px}.model-icon{font-size:32px;line-height:1}.model-label{font-size:16px;font-weight:500}.peak-model-selector-footer{border-top:1px solid #ffffff1a;display:flex;justify-content:center;margin-top:20px;padding-top:20px}.reset-models-btn{background:#f443;border:2px solid #ff444480;border-radius:8px;color:#f44;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s ease}.reset-models-btn:hover{background:#ff44444d;border-color:#ff4444b3;box-shadow:0 4px 12px #ff44444d;transform:translateY(-2px)}.auth-modal-overlay{align-items:flex-end;display:flex;inset:0;justify-content:center;padding-bottom:8vh;position:fixed;z-index:10000}@media (max-height:850px){.auth-modal-overlay{align-items:center;background:#0a0a0a;justify-content:center;padding:1rem 1rem 0}.auth-modal-overlay__loading{display:none}}.auth-modal-overlay__loading{background:#0a0a0a;inset:0;position:absolute;z-index:0}.auth-modal{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:16px;box-shadow:0 20px 60px #0006;max-width:400px;padding:2rem;position:relative;width:100%;z-index:1}.auth-modal-close{background:#ffffff1a;border:none;border-radius:6px;color:#fffc;cursor:pointer;font-size:1.5rem;height:2rem;line-height:1;padding:0;position:absolute;right:.75rem;top:.75rem;transition:background .2s,color .2s;width:2rem}.auth-modal-close:hover{background:#fff3;color:#fff}.auth-modal-header{margin-bottom:1.5rem;text-align:center}.auth-modal-header h2{color:#fff;font-size:1.5rem;font-weight:600;margin:0}.auth-modal-subtitle{color:#ffffffb3;font-size:.9rem;margin:.5rem 0 0}.auth-modal-form{display:flex;flex-direction:column;gap:1rem}.auth-modal-input{background:#ffffff14;border:1px solid #fff3;border-radius:8px;box-sizing:border-box;color:#fff;font-size:1rem;padding:.75rem 1rem;width:100%}.auth-modal-input::placeholder{color:#fff6}.auth-modal-input:focus{background:#ffffff1a;border-color:#fff6;outline:none}.auth-modal-input:disabled{cursor:not-allowed;opacity:.6}.auth-modal-submit{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:opacity .2s,transform .1s}.auth-modal-submit:hover:not(:disabled){opacity:.95;transform:translateY(-1px)}.auth-modal-submit:disabled{cursor:not-allowed;opacity:.6;transform:none}.auth-modal-sent{padding:.5rem 0;text-align:center}.auth-modal-sent p{color:#fff;font-size:1rem;margin:0 0 .5rem}.auth-modal-sent-hint{color:#fffc;font-size:.9rem;margin-bottom:1rem!important}.auth-modal-sent-hint strong{color:#fff}.auth-modal-back{background:#0000;border:1px solid #ffffff4d;border-radius:6px;color:#ffffffe6;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background .2s}.auth-modal-back:hover{background:#ffffff1a}.auth-modal-hint{color:#ffffff80;font-size:.85rem;margin:0}.auth-modal-error{background:#f8717126;border-radius:6px;color:#f87171;font-size:.85rem;margin:0;padding:.5rem}.auth-modal-powered{border-top:1px solid #ffffff1a;color:#ffffff80;font-size:.8rem;margin-top:1.25rem;padding-top:1rem;text-align:center}.auth-modal-powered-link{align-items:center;color:#ffffffb3;display:inline-flex;gap:.35rem;text-decoration:none;transition:color .2s}.auth-modal-powered-link:hover{color:#3ecf8e}.auth-modal-powered-icon{height:16px;opacity:.9;vertical-align:middle;width:16px}.cloud-sync-modal-overlay{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:99998}.cloud-sync-modal{background:#2a2a2a;border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 10px 40px #00000080;max-width:400px;padding:1.5rem}.cloud-sync-modal h3{color:#fff;font-size:1.1rem;margin:0 0 .75rem}.cloud-sync-modal p{color:#ffffffd9;font-size:.95rem;line-height:1.4;margin:0 0 1.25rem}.cloud-sync-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.cloud-sync-btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:opacity .2s}.cloud-sync-btn:hover{opacity:.9}.cloud-sync-btn-primary{background:#4a9eff;color:#fff}.cloud-sync-btn-secondary{background:#ffffff26;color:#ffffffe6}body,html{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.close-button,.delete-marker-btn,.image-delete-btn,.image-enlarge-btn,.link-edit-btn,.map-search-container,.nav-button,.note-tooltip-empty-button,.project-action-btn,.project-actions-modal,.project-actions-modal-overlay,.project-actions-trigger,.resize-handle,.slider-arrow,.tooltip-close-btn,.tooltip-edit-btn,.tooltip-file-btn,[role=button],a,button{touch-action:manipulation}[contenteditable=true],input,textarea{-webkit-user-select:text;user-select:text}body{background-color:#121212;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;overflow:hidden}.App{display:flex;flex-direction:column;height:100vh;position:relative}.main-content{display:flex;flex-grow:1;touch-action:manipulation}.canvas-container{flex-grow:1;height:100vh;left:0;position:absolute;top:0;touch-action:none;width:100%;z-index:1}.canvas-container canvas{touch-action:none}.map-search-overlay{left:auto;opacity:.2;pointer-events:none;position:absolute;right:16px;top:16px;transition:opacity .2s ease;z-index:10}.map-search-overlay.map-search-revealed{opacity:1}.map-search-overlay .map-search-container{pointer-events:auto}.map-search-container{background-color:initial;height:40px;min-height:40px;min-width:40px;padding:0;transition:width .2s ease,min-width .2s ease,max-width .2s ease;width:40px}.map-search-overlay.map-search-revealed .map-search-container{height:auto;max-width:800px;min-height:0;min-width:560px;width:auto}.map-search-input-wrap{align-items:center;background-color:#2a2a2a;border:1px solid #444;border-radius:6px;display:flex;flex-direction:row-reverse;height:40px;overflow:hidden;position:relative;transition:border-color .2s}.map-search-overlay.map-search-revealed .map-search-input-wrap{border-color:#444}.map-search-overlay.map-search-revealed .map-search-input-wrap:focus-within{border-color:#f44}.map-search-icon{align-items:center;color:#888;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:color .2s;width:40px}.map-search-overlay.map-search-revealed .map-search-icon{color:#aaa;width:36px}.map-search-icon svg{height:18px;width:18px}.map-search-overlay.map-search-revealed .map-search-icon svg{height:16px;width:16px}.map-search-input{background-color:initial;border:none;color:#e0e0e0;flex:0 1;font-family:inherit;font-size:14px;margin:0;min-width:0;outline:none;overflow:hidden;padding:0;transition:flex .2s ease,padding .2s ease;width:0}.map-search-overlay.map-search-revealed .map-search-input{flex:1 1;min-width:0;padding:8px 48px 8px 12px}.map-search-input::placeholder{color:#888}.map-search-clear{background:none;border:none;border-radius:50%;color:#888;cursor:pointer;font-size:14px;padding:4px;position:absolute;right:8px;transition:color .2s}.map-search-overlay.map-search-revealed .map-search-clear{right:8px}.map-search-clear:hover{color:#e0e0e0}h1{display:none}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.group-label{background-color:initial;border-radius:12px;color:#e0e0e0;font-size:14px;font-weight:600;padding:4px 10px;pointer-events:auto;transition:background-color .2s;white-space:nowrap;z-index:999}.group-label-clickable:hover,.group-label-editing,.group-label-with-plaque .group-label,.group-label:hover{background-color:#1d1d1d}.group-label-editing{border-radius:12px;padding:4px 10px;pointer-events:auto}.group-label-input:focus{background:#232323;border-width:2px}.group-label-color-picker::-webkit-color-swatch-wrapper{padding:0}.group-label-color-picker::-webkit-color-swatch{border:none;border-radius:2px}.group-label-color-picker::-moz-color-swatch{border:none;border-radius:2px}.group-label-save-btn:hover{background:#444;color:#fff}.marker-preview-c2d{pointer-events:none;z-index:1000}
/*# sourceMappingURL=main.98952350.css.map*/