:root{--background-color: black;--text-color: #aaaaaa}@media (prefers-color-scheme: dark){:root{--background-color: #161718}}body{margin:0;padding:0;display:flex;justify-content:center;min-height:100vh;position:relative;overflow-x:hidden}main{width:100%;max-width:100vw;display:flex;flex-direction:column;align-items:center;overflow-x:hidden;box-sizing:border-box;padding:0 20px;transition:margin-left .3s ease}.title-header{padding:20px 40px;margin-bottom:5px;text-align:center}.title-header h1{margin:0;font-size:24px;font-weight:700;color:var(--text-color)}.login-status{position:fixed;top:20px;right:20px;display:flex;align-items:center;gap:10px;z-index:1000}.title-header .datetime{margin-top:8px;font-size:14px;color:var(--text-color);opacity:.8}.title-header .selected-state-name{margin-top:16px;font-size:13px;color:#4caf50;font-weight:500;padding:4px 12px;border-radius:4px;background:#4caf501a;display:inline-block;cursor:help;transition:all .2s ease}.title-header .selected-state-name:hover{background:#4caf5033;transform:scale(1.02)}g.note.transparent:hover{opacity:1}g.note{fill:var(--background-color);stroke-width:1px;stroke:var(--text-color);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}g.note.selected>circle{opacity:1;stroke-dasharray:4,4;stroke-width:3px;stroke:var(--text-color)}g.note.hidden{opacity:0}g.note.transparent{opacity:.3}g.note.transparent>text{opacity:1;color:inherit}g.note.force-transparent{opacity:.5!important}g.note.force-transparent>text{opacity:1!important}g.note.visible{opacity:1}g.note.blue{fill:var(--color-level1-blue-fill)}g.note.blue>text{stroke:#fff;fill:#fff}g.note.trans{fill:var(--color-level1-trans-fill)}g.note.trans>text{stroke:#fff;fill:#fff}g.note.gray{fill:var(--color-level1-gray-fill)}g.note.gray>text{stroke:#fff;fill:#fff}g.note.red{fill:var(--color-level1-red-fill)}g.note.red>text{stroke:#fff;fill:#fff}g.note.green{fill:var(--color-level1-green-fill)}g.note.green>text{stroke:#fff;fill:#fff}g.note.brown{fill:var(--color-level1-brown-fill)}g.note.brown>text{stroke:#fff;fill:#fff}path.string{stroke:var(--text-color)!important;fill:none;pointer-events:none;stroke-width:1px!important}path.frets{stroke:var(--text-color)!important;stroke-width:1px;fill:none}g.note>text{stroke:var(--text-color);stroke-width:0px;fill:var(--text-color);text-anchor:middle;dominant-baseline:middle;font-size:18px;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}#editable-div{text-align:center;font-size:18px}#fretboard-diagram-creator{padding-top:10px;display:flex;justify-content:center;width:100%;max-width:100%;position:relative;z-index:1;overflow-x:auto;box-sizing:border-box}div.menu{text-align:center;padding:20px 0;position:relative;z-index:1;isolation:isolate;transform:translateZ(0);will-change:transform;display:flex;flex-direction:row;gap:40px;align-items:flex-start;justify-content:center;flex-wrap:wrap}.menu-left,.menu-right{display:flex;flex-direction:column;gap:20px;align-items:center}text.marker{text-anchor:middle;dominant-baseline:middle;font-size:16px;font-weight:700;fill:var(--text-color);opacity:1!important;visibility:visible!important;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}g.markers{opacity:1!important;visibility:visible!important}#color-selector{margin:0;padding:12px 16px;width:400px;display:flex;flex-direction:column;gap:10px;background:transparent;border:none;box-shadow:none}.color-palette-row{display:flex;justify-content:center;align-items:center;gap:8px;padding:0}.palette-label{font-size:13px;color:var(--text-color);width:55px;text-align:right;margin-right:6px}button.color{width:40px;height:40px;border-radius:4px;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:border-color .2s}button.color.color-tint{width:32px;height:32px;border-radius:4px}button.color.color-tint.selected{box-shadow:0 0 0 3px var(--text-color),0 0 8px #ffffff80;transform:scale(1.1);border-width:2px}button.color:hover{border-color:#fff6}button.color.selected{box-shadow:0 0 0 2px var(--text-color)}button.color.level2.selected{border-width:7px;box-shadow:0 0 0 1px var(--text-color)}button{height:25px}.button{background:#ffffff0d;color:var(--text-color);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:6px 14px;cursor:pointer;font-size:14px;min-width:70px;height:32px;display:inline-flex;align-items:center;justify-content:center;transition:background-color .2s,border-color .2s}.button:hover{background:#ffffff1a;border-color:#ffffff4d}.button:active{background:#ffffff14}.color.blue{background-color:var(--color-level1-blue-button)}.color.trans{background-color:var(--color-level1-trans-button)}.color.green{background-color:var(--color-level1-green-button)}.color.red{background-color:var(--color-level1-red-button)}.color.brown{background-color:var(--color-level1-brown-button)}.color.gray{background-color:var(--color-level1-gray-button)}.color.level2{background-color:transparent;border:6px solid;box-sizing:border-box}.color.level2.yellow{border-color:var(--color-level2-yellow)}.color.level2.cyan{border-color:var(--color-level2-cyan)}.color.level2.pink{border-color:var(--color-level2-pink)}.color.level2.grass-green{border-color:var(--color-level2-grass-green)}.color.level2.orange{border-color:var(--color-level2-orange)}.color.level2.white{border-color:var(--color-level2-white);border-width:6px}#delete-palette{width:60px;background-color:#f44;color:#fff;border:1px solid var(--text-color);border-radius:4px;cursor:pointer}#delete-palette:hover{background-color:#f66;transform:scale(1.05)}#delete-palette.selected{border:2px solid var(--text-color);box-shadow:0 0 8px #f44c}#enharmonic{background:#ffffff0d;color:var(--text-color);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:0;cursor:pointer;font-size:16px;min-width:32px;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;transition:background-color .2s,border-color .2s}#enharmonic:hover{background:#ffffff1a;border-color:#ffffff4d}#enharmonic:active{background:#ffffff14}#global-actions{margin:0;width:auto;display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap;padding:0;background:transparent;border:none}figure.half-full{display:flex;justify-content:center;width:100%;max-width:100%;margin:0 auto;position:relative;z-index:1;isolation:isolate;overflow-x:auto;box-sizing:border-box}figure.half-full svg{display:block;position:relative;z-index:1;isolation:isolate;max-width:100%;height:auto}.error{font-size:18px;text-anchor:middle}.mode-switch{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 8px;border-radius:4px;transition:background-color .2s}.mode-switch:hover{background-color:#ffffff0d}.mode-switch input[type=checkbox]{cursor:pointer;width:18px;height:18px}.mode-switch span{font-size:14px;color:var(--text-color)}#piano-keyboard-container{display:flex;justify-content:center;padding:15px 0;position:relative;z-index:1}.piano-keyboard{display:inline-block}.piano-keys{display:flex;position:relative;border:1px solid var(--text-color);border-radius:4px;padding:4px;background-color:var(--background-color);height:130px}.piano-key{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .1s ease}.piano-key.white-key{width:45px;height:130px;background:#fff;border:1px solid rgba(0,0,0,.2);border-radius:0 0 4px 4px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:10px;position:relative;margin-right:2px}.piano-key.white-key:hover{background:#f5f5f5}.piano-key.white-key.selected{background:#d0d0ff;border-color:#4682b4;border-width:2px}.piano-key.black-key{width:28px;height:80px;background:#333;border:1px solid #000;border-radius:0 0 3px 3px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:8px;position:absolute;top:4px;z-index:2}.piano-key.black-key:hover{background:#444}.piano-key.black-key.selected{background:#6b6bff;border-color:#4682b4;border-width:2px}.key-label{font-size:13px;font-weight:700;color:var(--text-color)}.piano-key.white-key .key-label{color:#333}.piano-key.white-key.selected .key-label{color:#000}.piano-key.black-key .key-label,.piano-key.black-key.selected .key-label{color:#fff}.connection{pointer-events:stroke;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round;opacity:1}.connection-preview{pointer-events:none}.connection-toolbar-container{pointer-events:all;z-index:101;overflow:visible!important;width:100%;height:100%;clip-path:none!important;clip:auto!important;overflow-x:visible!important;overflow-y:visible!important;isolation:isolate}.connection-toolbar{background:transparent;border:none;border-radius:6px;padding:6px 8px;box-shadow:none;display:flex;align-items:center;position:relative;overflow:visible!important;width:max-content;height:max-content;clip-path:none!important;clip:auto!important;-webkit-backdrop-filter:none;backdrop-filter:none}.toolbar-icons{display:flex;align-items:center;gap:4px}.toolbar-icon-wrapper{position:relative;overflow:visible!important;z-index:102;isolation:isolate}.toolbar-icon-btn{background:#ffffff0d;color:var(--text-color);border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:6px 10px;cursor:pointer;font-size:14px;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:background-color .2s,border-color .2s;white-space:nowrap;pointer-events:auto!important;position:relative;z-index:104}.toolbar-icon-btn:hover{background:#ffffff1a;border-color:#ffffff4d}.toolbar-icon-btn:active{background:#ffffff14}.toolbar-icon-btn.active{background:#4682b433;border-color:#4682b4;color:#a0c4e8}.toolbar-icon-btn.delete-icon-btn{color:#ff6b6b;border-color:#ff6b6b;background:#ff6b6b1a}.toolbar-icon-btn.delete-icon-btn:hover{background:#ff6b6b33;border-color:#ff5252}.toolbar-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;box-shadow:0 2px 8px #0000004d;min-width:100px;width:max-content;max-width:none;z-index:103!important;padding:4px;white-space:nowrap;overflow:visible!important;display:block!important;visibility:visible!important;clip-path:none!important;clip:auto!important;transform:translateZ(0);will-change:transform;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toolbar-icon-wrapper .toolbar-dropdown.toolbar-dropdown-up,.toolbar-dropdown.toolbar-dropdown-up{top:auto!important;bottom:calc(100% + 4px)!important}.toolbar-dropdown button{display:block;width:100%;min-width:100px;background-color:transparent;color:var(--text-color);border:none;border-radius:3px;padding:6px 12px;cursor:pointer;font-size:14px;text-align:left;transition:background-color .2s;white-space:nowrap;box-sizing:border-box}.toolbar-dropdown button:hover{background-color:#ffffff1a}.toolbar-dropdown button.active{background-color:#4682b44d;color:#a0c4e8}.toolbar-slider-wrapper{padding:8px 12px;display:flex;align-items:center;gap:10px;min-width:150px;background:transparent}.toolbar-slider-wrapper input[type=range]{flex:1;cursor:pointer;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;outline:none}.toolbar-slider-wrapper input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#fff;border:2px solid #4a90e2;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0003;margin-top:-5px}.toolbar-slider-wrapper input[type=range]::-webkit-slider-runnable-track{width:100%;height:6px;background:#fff3;border-radius:3px}.toolbar-slider-wrapper input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#fff;border:2px solid #4a90e2;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0003}.toolbar-slider-wrapper input[type=range]::-moz-range-track{width:100%;height:6px;background:#fff3;border-radius:3px}.toolbar-slider-wrapper span{min-width:35px;text-align:right;font-size:12px;color:var(--text-color)}.fret-range-slider-wrapper{display:flex;align-items:center;justify-content:center;padding:10px;margin:12px auto;max-width:500px;width:100%;box-sizing:border-box}.dual-range-slider{position:relative;width:100%;height:50px}.dual-range-inputs-container{position:relative;margin:auto;width:80%;height:100%;padding:0 9px}.dual-range-track{position:absolute;top:40px;left:9px;right:9px;height:6px;background:#fff3;border-radius:3px;z-index:0}.dual-range-selected{position:absolute;top:40px;height:6px;background:#4a90e2;border-radius:3px;pointer-events:none;z-index:1;transition:left .1s ease,width .1s ease}.dual-range-input{position:absolute;width:calc(100% - 18px);left:9px;height:6px;top:40px;background:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;pointer-events:none;cursor:pointer;margin:0;padding:0;z-index:2}.dual-range-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:#fff;border:2px solid #4a90e2;border-radius:50%;cursor:pointer;pointer-events:all;position:relative;z-index:3;margin-top:-6px;box-shadow:0 2px 4px #0003;transition:border-color .2s}.dual-range-input::-webkit-slider-thumb:hover{border-color:#5a9fe2}.dual-range-input::-moz-range-thumb{width:18px;height:18px;background:#fff;border:2px solid #4a90e2;border-radius:50%;cursor:pointer;pointer-events:all;position:relative;z-index:3;box-shadow:0 2px 4px #0003;transition:border-color .2s}.dual-range-input::-moz-range-thumb:hover{border-color:#5a9fe2}.dual-range-input::-webkit-slider-runnable-track{width:100%;height:6px;background:transparent;border-radius:3px}.dual-range-input::-moz-range-track{width:100%;height:6px;background:transparent;border-radius:3px}.dual-range-input-min{z-index:2}.dual-range-input-max{z-index:3}.fret-value-tooltip{position:absolute;top:8px;font-size:13px;font-weight:500;color:var(--text-color);white-space:nowrap;pointer-events:none;z-index:4;transition:left .1s ease;text-align:center}.button.selected{background:#4682b433;border:1px solid steelblue;color:#a0c4e8}g.note.preview-hover{opacity:1}g.note.preview-hover>circle{stroke-dasharray:3,3;stroke-width:2px;stroke:var(--text-color)}@media (max-width: 1600px){figure.half-full svg{max-width:calc(100vw - 40px)}}@media (max-width: 1200px){main{padding:0 15px}figure.half-full svg{max-width:calc(100vw - 30px)}}@media (max-width: 768px){html,body,#app{overflow-x:hidden!important;width:100%;max-width:100%;position:relative}main{overflow-x:hidden!important;width:100%;max-width:100%;position:relative;padding:0 10px}figure.half-full{overflow-x:auto!important;overflow-y:hidden!important;-webkit-overflow-scrolling:touch;width:100%;max-width:100vw;justify-content:flex-start!important}#fretboard-diagram-creator{overflow-x:auto!important;overflow-y:hidden!important;-webkit-overflow-scrolling:touch;width:100%;max-width:100vw;position:relative;justify-content:flex-start!important}#fretboard-diagram-creator svg{width:auto!important;min-width:fit-content!important;max-width:none!important;display:block;flex-shrink:0}div.menu{flex-direction:column!important;overflow-x:hidden!important;flex-wrap:nowrap!important;width:100%;max-width:100%;gap:12px!important;padding:20px 16px!important;box-sizing:border-box;margin:0}.menu-left,.menu-right{width:100%!important;max-width:100%!important;overflow-x:hidden!important;padding:0!important;box-sizing:border-box;margin:0}#color-selector{width:100%!important;max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box;padding:12px 0!important;margin:0}#global-actions{width:100%!important;max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box;padding:0!important;margin:0;justify-content:center}#connection-tool-section{width:100%!important;max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box;padding:8px 0!important;margin:0}#connection-tool-section>div{width:100%!important;max-width:100%!important;overflow-x:hidden!important;flex-wrap:wrap!important;box-sizing:border-box;justify-content:center;gap:4px!important}#connection-tool-section>div button{margin-right:0!important;margin-left:0!important}#download-section{width:100%!important;max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box;flex-wrap:wrap!important;padding:8px 0!important;margin:0!important;justify-content:center;gap:8px!important;align-items:center}#download-section label{margin:0!important;white-space:nowrap}#download-section button{margin-left:0!important;flex-shrink:0}#piano-keyboard-container{width:100%!important;max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box;padding:15px 0!important;margin:0}.piano-keyboard,.piano-keys{max-width:100%!important;overflow-x:hidden!important}.fret-range-slider-wrapper{width:100%!important;max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box;padding:10px 0!important;margin:0}}.fretboard-gallery{position:fixed;top:0;left:0;width:420px;height:100vh;background:var(--background-color);border-right:2px solid rgba(255,255,255,.1);display:flex;flex-direction:column;padding:0;margin:0;overflow:hidden;z-index:1000;transition:transform .3s ease;transform:translate(-100%)}.fretboard-gallery.open{transform:translate(0)}.gallery-toggle-btn{position:fixed;top:20px;left:20px;width:40px;height:40px;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:999;transition:all .3s ease;color:var(--text-color);font-size:20px}.gallery-toggle-btn:hover{background:#ffffff26;border-color:#ffffff4d}.gallery-toggle-btn.open{left:440px}.gallery-header{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:15px;position:relative;border-bottom:2px solid rgba(255,255,255,.1);flex-shrink:0}.gallery-title{font-size:18px;font-weight:700;color:var(--text-color);margin:0;text-align:left;flex:1}.gallery-clear-btn{padding:6px 12px;background:transparent;color:#f44336;border:2px solid #F44336;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;white-space:nowrap;min-width:50px;transition:background-color .2s,color .2s;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;line-height:1;margin:0;font-family:inherit}.gallery-clear-btn:hover{background:#f44336;color:#fff}.gallery-clear-btn:active{background:#f44336cc}.gallery-import-btn{padding:6px 12px;background:transparent;color:#5ba3d0;border:2px solid #5ba3d0;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;white-space:nowrap;min-width:50px;transition:background-color .2s,color .2s;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;line-height:1;margin:0;font-family:inherit}.gallery-import-btn:hover{background:#5ba3d0;color:#fff}.gallery-import-btn:active{background:#5ba3d0cc}.gallery-empty{text-align:center;color:var(--text-color);opacity:.6;padding:40px 20px;font-size:14px}.gallery-grid{display:flex;flex-direction:column;gap:12px;padding:15px 10px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0}.gallery-grid::-webkit-scrollbar{width:8px}.gallery-grid::-webkit-scrollbar-track{background:#ffffff0d}.gallery-grid::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.gallery-grid::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.gallery-item{width:100%;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border-radius:6px;overflow:visible;background:#ffffff08;border:2px solid transparent;position:relative;display:flex;flex-direction:column;align-items:center;padding:8px;gap:6px;box-sizing:border-box}.gallery-item:hover{transform:translate(-2px);box-shadow:0 2px 8px #0000004d;border-color:#fff3;background:#ffffff0d}.gallery-item.selected{border-color:#4caf50;border-width:3px;box-shadow:0 0 0 3px #4caf5066,0 4px 12px #4caf504d;transform:translateY(-2px)}.gallery-item.selected:after{content:"✔";position:absolute;top:8px;right:8px;width:24px;height:24px;background:#4caf50;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-shadow:0 2px 8px #4caf5099;z-index:10;pointer-events:none}.gallery-thumbnail-wrapper{position:relative;width:100%;height:120px;background:var(--background-color);overflow:hidden;border-radius:4px;flex-shrink:0}.gallery-thumbnail{width:100%;height:100%;object-fit:cover;background:var(--background-color)}.gallery-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-color);opacity:.5;font-size:12px;background:var(--background-color)}.gallery-delete-btn{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:3px;background:#000000b3;color:#fff;border:none;cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease,background .2s ease}.gallery-item:hover .gallery-delete-btn{opacity:1}.gallery-delete-btn:hover{background:#c80000e6}.gallery-share-btn{position:absolute;bottom:4px;right:4px;width:20px;height:20px;border-radius:3px;background:#000000b3;color:#fff;border:none;cursor:pointer;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease,background .2s ease;padding:0}.gallery-item:hover .gallery-share-btn{opacity:1}.gallery-share-btn:hover{background:#2196f3e6}.gallery-item-info{width:100%;text-align:center;min-width:0}.gallery-item-name{font-size:13px;color:var(--text-color);opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;padding:2px 4px;border-radius:3px;transition:background-color .2s;line-height:1.4}.gallery-item-name:hover{background-color:#ffffff1a;opacity:1}.gallery-item-name-input{font-size:12px;color:var(--text-color);background:var(--background-color);border:1px solid var(--text-color);border-radius:3px;padding:2px 4px;width:100%;box-sizing:border-box;outline:none}.gallery-item-name-input:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f34d}.import-dialog-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:#000000b3!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:9999!important;isolation:isolate!important}.import-dialog{background:var(--background-color)!important;border:2px solid var(--text-color)!important;border-radius:8px!important;padding:20px!important;max-width:500px!important;width:90%!important;max-height:80vh!important;overflow-y:auto!important;position:relative!important;z-index:10000!important}.import-dialog h3{margin:0 0 10px;color:var(--text-color);font-size:18px}.import-textarea{width:100%;min-height:100px;padding:10px;border:1px solid var(--text-color);border-radius:4px;background:var(--background-color);color:var(--text-color);font-family:monospace;font-size:12px;resize:vertical;box-sizing:border-box;margin-bottom:15px}.import-textarea:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f34d}.import-dialog-buttons{display:flex;gap:10px;justify-content:flex-end}@media (max-width: 768px){.fretboard-gallery{width:280px}.gallery-toggle-btn.open{left:300px}.gallery-header{padding:10px}.gallery-title{font-size:16px}.gallery-grid{padding:10px;gap:10px}.gallery-item{padding:6px;gap:8px}.gallery-thumbnail-wrapper{width:240px;height:105px}.gallery-item-name{font-size:12px}.import-dialog{width:95%;padding:15px}.directory-tab{min-width:50px;max-width:100px;padding:5px 8px;font-size:11px}.directory-tab-add{width:24px;height:24px;font-size:14px}}.directory-tabs{border-bottom:1px solid rgba(255,255,255,.1);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;flex-shrink:0}.directory-tabs::-webkit-scrollbar{height:4px}.directory-tabs::-webkit-scrollbar-track{background:#ffffff0d}.directory-tabs::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.directory-tabs::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.tabs-container{display:flex;gap:4px;min-width:fit-content}.directory-tab{position:relative;display:flex;align-items:center;gap:6px;padding:6px 12px;min-width:60px;max-width:150px;background:#ffffff0d;border:1px solid transparent;border-bottom:none;border-radius:4px 4px 0 0;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.directory-tab:hover{background:#ffffff1a}.directory-tab.active{background:var(--background-color);border-color:#ffffff1a;border-bottom-color:var(--background-color);margin-bottom:-1px;padding-bottom:7px}.directory-tab-name{flex:1;font-size:12px;color:var(--text-color);opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.directory-tab.active .directory-tab-name{opacity:1;font-weight:500}.directory-tab-input{flex:1;font-size:12px;color:var(--text-color);background:var(--background-color);border:1px solid var(--text-color);border-radius:3px;padding:2px 4px;outline:none;min-width:50px}.directory-tab-input:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f34d}.directory-tab-close{width:16px;height:16px;border-radius:2px;background:transparent;color:var(--text-color);border:none;cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:.5;transition:all .2s ease;padding:0}.directory-tab-close:hover{opacity:1;background:#c8000033;color:#ff6b6b}.directory-tab-add{display:flex;align-items:center;justify-content:center;width:28px;height:28px;margin:2px 0;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:var(--text-color);cursor:pointer;font-size:16px;line-height:1;transition:all .2s ease;padding:0}.directory-tab-add:hover{background:#ffffff1a;border-color:#fff3}.gallery-export-btn{padding:6px 12px;background:transparent;color:#5ba3d0;border:2px solid #5ba3d0;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;white-space:nowrap;min-width:50px;transition:background-color .2s,color .2s;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;line-height:1;margin:0;font-family:inherit}.gallery-export-btn:hover{background:#5ba3d0;color:#fff}.gallery-export-btn:active{background:#5ba3d0cc}.directory-context-menu{background:#1e1e1efa;border:1px solid rgba(255,255,255,.2);border-radius:6px;box-shadow:0 4px 12px #00000080;overflow:hidden;min-width:160px}.context-menu-item{padding:10px 16px;color:var(--text-color);cursor:pointer;transition:background .2s;font-size:14px;-webkit-user-select:none;user-select:none}.context-menu-item:hover{background:#4a90e233}.toast{position:fixed;bottom:20px;right:20px;min-width:200px;max-width:400px;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:10000;animation:slideIn .3s ease-out;font-size:14px;line-height:1.5;word-wrap:break-word}.toast.exiting{animation:slideOut .3s ease-in forwards}.toast-content{color:#fff;text-align:center}.toast.info{background:#2196f3f2;border-left:4px solid #2196F3}.toast.success{background:#4caf50f2;border-left:4px solid #4CAF50}.toast.error{background:#f44336f2;border-left:4px solid #F44336}.toast.warning{background:#ff9800f2;border-left:4px solid #FF9800}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@media (max-width: 768px){.toast{bottom:10px;right:10px;left:10px;max-width:none;min-width:auto}}.login-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.login-modal{background:linear-gradient(145deg,#1e1e1e,#2a2a2a);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:40px;max-width:450px;width:90%;box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff0d inset;animation:slideUp .3s ease-out}.login-modal h2{margin:0 0 8px;font-size:28px;font-weight:600;background:linear-gradient(135deg,#4a90e2,#5a9fe2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-description{margin:0 0 32px;color:#aaa;font-size:14px;line-height:1.5}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:10px;font-weight:500;color:#e0e0e0;font-size:14px;letter-spacing:.3px}.form-group input{width:100%;padding:14px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:10px;font-size:15px;color:#fff;box-sizing:border-box;transition:all .3s ease}.form-group input::placeholder{color:#666}.form-group input:focus{outline:none;background:#ffffff14;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e226,0 0 20px #4a90e21a}.form-group input:disabled{background:#ffffff05;cursor:not-allowed;opacity:.5}.error-message{background:#f4433626;border:1px solid rgba(244,67,54,.3);color:#ff6b6b;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:20px;display:flex;align-items:center;gap:8px;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-message:before{content:"⚠";font-size:16px}.button-group{display:flex;gap:12px;margin-top:8px}.btn-primary{flex:1;padding:14px 28px;background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;box-shadow:0 4px 15px #4a90e24d;display:flex;align-items:center;justify-content:center;text-align:center}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-primary:hover:not(:disabled):before{left:100%}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#357abd,#4a90e2);transform:translateY(-2px);box-shadow:0 6px 20px #4a90e266}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{background:#ffffff1a;cursor:not-allowed;box-shadow:none;opacity:.5}.login-note{margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1)}.login-note p{margin:0;font-size:13px;color:#888;display:flex;align-items:center;gap:6px}.login-note p:before{content:"ℹ";font-size:14px;color:#4a90e2}.close-button{position:absolute;top:16px;right:16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);width:36px;height:36px;border-radius:8px;font-size:24px;cursor:pointer;color:#999;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;line-height:1}.close-button:hover{background:#ffffff1a;border-color:#fff3;color:#fff;transform:rotate(90deg)}
